打印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:
按照它的快捷键格式化后,没有任何反馈(成功或失败),而且快捷键貌似会冲突。