打印mybatis可执行的sql语句的IDEA插件

前言

Mybatis打印了类似如下的语句

2020-07-21 17:49:31.772 [] [main] DEBUG c.d.d.s.mapper.MyUserMapper.select - ==>  Preparing: SELECT * FROM my_user WHERE (account=? and create_time=? and dr=?) 
2020-07-21 17:49:31.787 [] [main] DEBUG c.d.d.s.mapper.MyUserMapper.select - ==> Parameters: ironman(String), 2020-06-05 16:57:42.0(Timestamp), 0(Integer)
2020-07-21 17:49:31.837 [] [main] DEBUG c.d.d.s.mapper.MyUserMapper.select - <==      Total: 0

有时候我们需要的是可以直接执行的sql语句,即帮我们将问号替换成实际的值。IDEA有哪些插件可以实现呢? 本文研究这个。

IDEA插件
  • SQL Params Setter (推荐)

  • MyBatis Sql Query Log Binder (不太推荐)

  • Mybatis Log Plugin(不推荐)

  • MybatisLogFormat (严重不推荐,列出来只是为了避坑)

  • Mybatis Log (不推荐)

这里先说明一下这些插件的使用方法,大致是相同的。选中Console中的mybatis打印出来的sql语句,然后进行解析(就是替换问号为实际值的过程)。

解析后的 “可执行的sql” 的结果一般自动拷贝到剪切板里,这个sql一般是格式化成美观的格式的。这些插件有些做得比较好,解析成功或者失败都有反馈,有些插件没任何反馈。另外有些只有一个快捷键,有些提供了右键菜单。有些功能更加强大,例如Mybatis Log Plugin 甚至提供了拦截器,从而无需手动解析sql,解析好的sql自动呈现。

下面是详细解释各个插件的优缺点

SQL Params Setter:
    推荐。选中日志中的sql,可直接在右键菜单选择`SQL Params Setter`,格式化成功或失败都有弹框反馈,解析后的结果直接出现在剪切板,结果是格式化的sql并且填入了参数。这个插件选中的sql只要包含Preparing和Parameters就行了,非常灵活,无需刻意选中两行,只要包含关键字即可。
  
MyBatis Sql Query Log Binder:
    不太推荐。有了SQL Params Setter就没必要安装这个了。也是选中sql,然后选择Tools->Bind Query Log,但是首先选择的sql的容错性没有SQL Params Setter这么高。并且不是右键菜单,必须在菜单中选择Bind Query Log,有点不方便。
    
Mybatis Log Plugin:
    不推荐。免费版只支持2019的IDEA,并且还有重复打印sql的bug。2020的IDEA要收费不说,而且即使你购买了因为你的IDEA是盗版的所以还是用不了。
    
MybatisLogFormat:
    严重不推荐。格式化的sql都是有错的,如果带有日期会出错,字符串类型的也不会带有单引号, 是一款非常敷衍的插件。
    
Mybatis Log:
  按照它的快捷键格式化后,没有任何反馈(成功或失败),而且快捷键貌似会冲突。
Logo

开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!

更多推荐