伙伴云客服论坛»论坛 S区 S软件开发 查看内容

0 评论

0 收藏

分享

MyBatis Log 插件无法显示SQL语句的原因解析

Mybatis有什么用
前两天跟阿里的大牛聊天,他讲到对于性能要求高,需求变化多的互联网项目来说,用在sql优化上的开发时间是大头,有时候代码写出来一小时,优化反反复复可能要几个星期,这时候Mybatis这种配置比较灵敏的框架优势就显现了!Mybatis为什么在国内这么流行?
1. 什么是Mybatis?
MyBatis是支持定制化sql、存储过程以及高级映射的优秀的耐久层框架。MyBatis防止了几乎所有的JDBC代码和手工设置参数以及抽取结果集。MyBatis使用简单的XML或注解来配置和映射根本体,将接口和Java映射成数据库中的记录。
2. Mybatis为什么有优势?
l 简单易学:自身就很小且简单。没有任何第三方依赖,最简单装置只要两个jar文件+配置几个sql映射文件易于学习,易于使用,与JDBC相比,减少了50%以上的代码量。
l 灵敏:Mybatis 不会对应用程序或者数据库的现有设计强加任何影响,SQL写在XML里,从程序代码中彻底分别,降低耦合度,便于统一管理和优化,可重用。
l 解除sql与程序代码的耦合:通过提供DAO层,将业务逻辑和数据访问逻辑分别,使系统的设计更明晰,更易维护,更易单元测试。sql和代码的分别,进步了可维护性。
l 提供映射标签,支持对象与数据库的ORM字段关系映射
l 提供对象关系映射标签,支持对象关系组建维护
l 提供XML标签,支持编写动态sql。
3. Mybatis为什么在国内这么流行?
1、历史悠久
MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目改名为MyBatis 。
2、阿里推动
其实十年前我们主要使用的ORM框架就是iBatis,而阿里巴巴是对国内Java开发者影响最大的一家公司。阿里在国内Java社区的影响力有目共睹,阿里对Java社区奉献了很多实用的开源工具,并且国内Java开发者对于阿里开源的产品接纳水平也最高。
早期阿里系离任工程师的影响力也不可小觑,这些从阿里离任的工程师进入了各个规模的公司, 通常也有担任较高的职位, 拥有着相对较多的话语权, 在新公司继续使用自己熟悉的iBatis就是再正常不过的了。
3、互联网大环境下的选择
MyBatis封装较少,提供的切入点较多,适宜停止架构。遇到超级复杂的场景的时候有不错的sql支持。简单高效,优化起来也方便,比较符合如今的开发节奏,互联网公司都是先快速开发占领市场,然后再优化代码。而且这个过程需求经常是变来变去的,开发人员也有活动性,为了便于管理,所以大家都选择了Mybatis。
好了,开端咱今天的正文
MyBatis Log是IDEA一款下载量非常高的插件,该插件可以对控制台打印的日志停止解析,然后将对应的SQL语句整理并拼接好对应的参数,非常方便。有时插件却无法打印SQL,总的来说,有如下三种原因:
mybatis装置地址
https://plugins.jetbrains.com/plugin/10065-mybatis-log-plugin/versions
1. 项目的日志等级过高,修改日志等级为 DEBUG 或 INFO
  1. ## log4j.properties 文件
  2. log4j.rootLogger = DEBUG,stdout,D
  3. 或者
  4. ## application-dev.yml 文件
  5. loggig:
  6.   level:
  7.     root: DEBUG
复制代码
2. mybatis配置中没有设置将sql日志输出到控制台
  1. ## mybatis-config.xml 文件
  2. <configuration>
  3.   <settings>
  4.     <setting name="logImpl" value="org.apache.ibatis.logging.stdout.StdOutImpl" />
  5.   </settings>
  6. </configuration>
  7. 或者
  8. ## application-dev.yml 文件
  9. mybatis-plus:
  10. configuration:
  11.    ## 日志
  12.    log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
复制代码
3. 控制台打印的日志格式不符合规范,插件无法解析
  1. 修改日志打印的格式即可,推荐格式如下:
  2. ## log4j.properties 文件
  3. ###控制台日志输出###
  4. log4j.appender.stdout = org.apache.log4j.ConsoleAppender
  5. log4j.appender.stdout.Target = System.out
  6. log4j.appender.stdout.layout = org.apache.log4j.PatternLayout
  7. log4j.appender.stdout.layout.ConversionPattern = [%p] - [%t] - [%d{yyyy-MM-dd HH\:mm\:ss\:SSS}] - (%c{1}\:%L) - %m%n
  8. 或者
  9. ## application.yml 文件
  10. # 日志设置配置
  11. logging:
  12. pattern:
  13.   console: '%X{RequestNo}-%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger{36}[%L] - %msg%n'
复制代码
总结
到此这篇关于MyBatis Log 插件无法显示SQL语句的原因的文章就介绍到这了,更多相关MyBatis Log 插件无法显示SQL语句内容请搜索网站以前的文章或继续阅读下面的相关文章希望大家以后多多支持网站!

回复

举报 使用道具

相关帖子
全部回复
暂无回帖,快来参与回复吧
本版积分规则 高级模式
B Color Image Link Quote Code Smilies

瑶耘
注册会员
主题 23
回复 23
粉丝 0
|网站地图
快速回复 返回顶部 返回列表