MyBatis Log 插件無法顯示SQL語句的原因解析
Mybatis有什么用
前兩天跟阿里的大牛聊天,他講到對于性能要求高,需求變化多的互聯(lián)網(wǎng)項(xiàng)目來說,用在sql優(yōu)化上的開發(fā)時(shí)間是大頭,有時(shí)候代碼寫出來一小時(shí),優(yōu)化反反復(fù)復(fù)可能要幾個(gè)星期,這時(shí)候Mybatis這種配置比較靈活的框架優(yōu)勢就顯現(xiàn)了!Mybatis為什么在國內(nèi)這么流行?
1. 什么是Mybatis?
MyBatis是支持定制化sql、存儲(chǔ)過程以及高級映射的優(yōu)秀的持久層框架。MyBatis避免了幾乎所有的JDBC代碼和手工設(shè)置參數(shù)以及抽取結(jié)果集。MyBatis使用簡單的XML或注解來配置和映射基本體,將接口和Java映射成數(shù)據(jù)庫中的記錄。
2. Mybatis為什么有優(yōu)勢?
l 簡單易學(xué):本身就很小且簡單。沒有任何第三方依賴,最簡單安裝只要兩個(gè)jar文件+配置幾個(gè)sql映射文件易于學(xué)習(xí),易于使用,與JDBC相比,減少了50%以上的代碼量。
l 靈活:Mybatis 不會(huì)對應(yīng)用程序或者數(shù)據(jù)庫的現(xiàn)有設(shè)計(jì)強(qiáng)加任何影響,SQL寫在XML里,從程序代碼中徹底分離,降低耦合度,便于統(tǒng)一管理和優(yōu)化,可重用。
l 解除sql與程序代碼的耦合:通過提供DAO層,將業(yè)務(wù)邏輯和數(shù)據(jù)訪問邏輯分離,使系統(tǒng)的設(shè)計(jì)更清晰,更易維護(hù),更易單元測試。sql和代碼的分離,提高了可維護(hù)性。
l 提供映射標(biāo)簽,支持對象與數(shù)據(jù)庫的ORM字段關(guān)系映射
l 提供對象關(guān)系映射標(biāo)簽,支持對象關(guān)系組建維護(hù)
l 提供XML標(biāo)簽,支持編寫動(dòng)態(tài)sql。
3. Mybatis為什么在國內(nèi)這么流行?
1、歷史悠久
MyBatis 本是apache的一個(gè)開源項(xiàng)目iBatis, 2010年這個(gè)項(xiàng)目改名為MyBatis 。
2、阿里推動(dòng)
其實(shí)十年前我們主要使用的ORM框架就是iBatis,而阿里巴巴是對國內(nèi)Java開發(fā)者影響最大的一家公司。阿里在國內(nèi)Java社區(qū)的影響力有目共睹,阿里對Java社區(qū)貢獻(xiàn)了很多實(shí)用的開源工具,并且國內(nèi)Java開發(fā)者對于阿里開源的產(chǎn)品接納程度也最高。
早期阿里系離職工程師的影響力也不可小覷,這些從阿里離職的工程師進(jìn)入了各個(gè)規(guī)模的公司, 通常也有擔(dān)任較高的職位, 擁有著相對較多的話語權(quán), 在新公司繼續(xù)使用自己熟悉的iBatis就是再正常不過的了。
3、互聯(lián)網(wǎng)大環(huán)境下的選擇
MyBatis封裝較少,提供的切入點(diǎn)較多,適合進(jìn)行架構(gòu)。遇到超級復(fù)雜的場景的時(shí)候有不錯(cuò)的sql支持。簡單高效,優(yōu)化起來也方便,比較符合現(xiàn)在的開發(fā)節(jié)奏,互聯(lián)網(wǎng)公司都是先快速開發(fā)占領(lǐng)市場,然后再優(yōu)化代碼。而且這個(gè)過程需求經(jīng)常是變來變?nèi)サ?,開發(fā)人員也有流動(dòng)性,為了便于管理,所以大家都選擇了Mybatis。
好了,開始咱今天的正文
MyBatis Log是IDEA一款下載量非常高的插件,該插件可以對控制臺打印的日志進(jìn)行解析,然后將對應(yīng)的SQL語句整理并拼接好對應(yīng)的參數(shù),非常方便。有時(shí)插件卻無法打印SQL,總的來說,有如下三種原因:
mybatis安裝地址
https://plugins.jetbrains.com/plugin/10065-mybatis-log-plugin/versions
1. 項(xiàng)目的日志等級過高,修改日志等級為 DEBUG 或 INFO
## log4j.properties 文件 log4j.rootLogger = DEBUG,stdout,D 或者 ## application-dev.yml 文件 loggig: level: root: DEBUG
2. mybatis配置中沒有設(shè)置將sql日志輸出到控制臺
## mybatis-config.xml 文件 <configuration> <settings> <setting name="logImpl" value="org.apache.ibatis.logging.stdout.StdOutImpl" /> </settings> </configuration> 或者 ## application-dev.yml 文件 mybatis-plus: configuration: ## 日志 log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
3. 控制臺打印的日志格式不符合規(guī)范,插件無法解析
修改日志打印的格式即可,推薦格式如下: ## log4j.properties 文件 ###控制臺日志輸出### log4j.appender.stdout = org.apache.log4j.ConsoleAppender log4j.appender.stdout.Target = System.out log4j.appender.stdout.layout = org.apache.log4j.PatternLayout log4j.appender.stdout.layout.ConversionPattern = [%p] - [%t] - [%d{yyyy-MM-dd HH\:mm\:ss\:SSS}] - (%c{1}\:%L) - %m%n 或者 ## application.yml 文件 # 日志設(shè)置配置 logging: pattern: console: '%X{RequestNo}-%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{36}[%L] - %msg%n'
總結(jié)
到此這篇關(guān)于MyBatis Log 插件無法顯示SQL語句的原因的文章就介紹到這了,更多相關(guān)MyBatis Log 插件無法顯示SQL語句內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
SpringBoot使用Guava實(shí)現(xiàn)日志脫敏的示例代碼
本文主要介紹了SpringBoot使用Guava實(shí)現(xiàn)日志脫敏的示例代碼,使用Guava中的Strings、Maps和CharMatcher類來進(jìn)行日志脫敏,保護(hù)敏感數(shù)據(jù)的安全,感興趣的可以了解一下2024-01-01理解Java中的靜態(tài)綁定和動(dòng)態(tài)綁定
這篇文章主要幫助大家理解Java中的靜態(tài)綁定和動(dòng)態(tài)綁定,在Java中存在兩種綁定方式,一種為靜態(tài)綁定,另一種就是動(dòng)態(tài)綁定,亦稱為后期綁定,感興趣的小伙伴們可以參考一下2016-02-02mybatis攔截器實(shí)現(xiàn)通用權(quán)限字段添加的方法
這篇文章主要給大家介紹了關(guān)于mybatis攔截器實(shí)現(xiàn)通用權(quán)限字段添加的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用mybatis具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-09-09