mybatis日志打印的两款IDEA插件推荐

 更新时间:2023年04月04日 09:41:57   作者:凡人歌者徐  
这篇文章主要给大家推荐介绍了关于mybatis日志打印的两款IDEA插件,文中通过图文以及实例代码介绍的非常详细,对大家学习或者使用mybatis具有一定的参考学习价值,需要的朋友可以参考下

前言

各位精通CRUD的老司机,相信大家在工作中mybatis或者mybatisplus使用的肯定是比较多的,那么大家或多或少都应该对下面的行为感到熟悉。我们排查问题的时候,从日志中复制出来的SQL参数位置都是使用?占位的,我们需要将一个一个的参数手动赋值到?的位置,随后该SQL才能放到数据库中正确执行。对于这样的操作,一次两次尚可接受,多了就会让人对于这种机械性的操作很是反感。那么,对于这个问题有没有比较好的解决方案呢?答案还真有,今天就给大家推荐两款不错的IDEA插件,这两款插件笔者也都使用过。

注:通常mybaits日志打印大概如下图示,一行是?占位的SQL,一行是各个参数值

MybatisLogFormat

这款插件可在IDEA的插件市场中搜索到并直接安装。使用的时候直接选中SQL行以及参数行,就是上面图示中红框圈出来的两行,鼠标点击右键,此时会弹出来一个对话框。

选项一

点击这个选项,会在右下角弹出一个小框,同时有个copy的按钮供你点击,一点击参数化的SQL就被复制到了你的剪切板,不过不是美化之后的格式。

update `t_student` set `name` = case when `id` = 1 then 张三 when `id` = 2 then 李四 when `id` = 3 then 王五 when `id` = 4 then 赵六 end, `age` = case when `id` = 1 then 40 when `id` = 2 then 34 when `id` = 3 then 55 when `id` = 4 then 76 end where `id` in ( 1 , 2 , 3 , 4 )

选项二

点击这个选项,参数化后的SQL直接被复制到你的剪切板,而且是美化之后的格式。

UPDATE `t_student`
SET `name` = CASE 
	WHEN `id` = 1 THEN 张三
	WHEN `id` = 2 THEN 李四
	WHEN `id` = 3 THEN 王五
	WHEN `id` = 4 THEN 赵六
END, `age` = CASE 
	WHEN `id` = 1 THEN 40
	WHEN `id` = 2 THEN 34
	WHEN `id` = 3 THEN 55
	WHEN `id` = 4 THEN 76
END
WHERE `id` IN (1, 2, 3, 4)

缺点

好像对字符串的支持不太完美,没有给字符串值加上 ’ 号,需要我们自己补全否则会报错。

Mybatis Log Free

这款插件可在IDEA的插件市场中搜索到并直接安装。使用的时候先在console控制台鼠标点击右键,在弹出的对话框中选择Mybatis Log Plugin选项,此时会出现Mybatis Log的专属控制台,之后程序运行中的参数化SQL就会直接打印在专属控制台中。

我们运行测试程序,观察出现在控制台中的SQL。

由此可见,参数化SQL被正确打印,而且对于不同字段类型处理正确,比如字符串值自动用 ’ 进行包裹,SQL可直接放到数据库中执行,非常完美。

总结

  1. Mybatis Log Free插件和MybatisLogFormat插件都能起到类似的作用,简化我们的工作。
  2. Mybatis Log Free插件似乎对于参数的处理更准确一点,当然也可能是我不太会用MybatisLogFormat插件,所以我现在就是使用Mybatis Log Free插件多一些。
  3. 自测Mybatis Log Free插件对于mybatisplus同样适用。

到此这篇关于mybatis日志打印的两款IDEA插件推荐的文章就介绍到这了,更多相关mybatis日志打印内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Spring实例化bean过程解析及完整代码示例

    Spring实例化bean过程解析及完整代码示例

    这篇文章主要介绍了Spring实例化bean过程解析及完整代码示例,简单分析实例化bean过程并且分享了相关实例,具有一定借鉴价值,需要的朋友可以参考下
    2018-01-01
  • Java多种方式动态生成doc文档

    Java多种方式动态生成doc文档

    这篇文章主要为大家详细介绍了Java动态生成doc文档的多种方式,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-09-09
  • Future cancel迷惑性boolean入参解析

    Future cancel迷惑性boolean入参解析

    这篇文章主要为大家介绍了Future cancel迷惑性boolean入参解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-02-02
  • MyBatisPlus3.x中使用代码生成器(全注释)

    MyBatisPlus3.x中使用代码生成器(全注释)

    这篇文章主要介绍了MyBatisPlus3.x中使用代码生成器(全注释),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-09-09
  • Feign超时 在yml文件里的配置方式

    Feign超时 在yml文件里的配置方式

    这篇文章主要介绍了Feign超时 在yml文件里的配置方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-06-06
  • 区块链java代码实现

    区块链java代码实现

    这篇文章主要为大家详细介绍了区块链java代码实现,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-01-01
  • Java创建数组、赋值的四种方式详解(声明+创建+初始化 )

    Java创建数组、赋值的四种方式详解(声明+创建+初始化 )

    数组是一种数据结构,用来存储同一类型值的集合一旦创建了数组,就不能再改变它的长度,下面这篇文章主要给大家介绍了关于Java创建数组、赋值的四种方式(声明+创建+初始化 )的相关资料,需要的朋友可以参考下
    2024-04-04
  • Java排序算法总结之归并排序

    Java排序算法总结之归并排序

    这篇文章主要介绍了Java排序算法总结之归并排序,较为详细的分析了归并排序的原理与java实现技巧,需要的朋友可以参考下
    2015-05-05
  • Struts2截取字符串代码介绍

    Struts2截取字符串代码介绍

    这篇文章主要介绍了Struts2截取字符串代码介绍,介绍了基本的截取方法,以及截取带html标签字符串的方法,需要的朋友可以了解下。
    2017-09-09
  • 详解Javaweb状态管理的Session和Cookie

    详解Javaweb状态管理的Session和Cookie

    这篇文章主要介绍了Javaweb状态管理的Session和Cookie,将浏览器与web服务器之间多次交互当做一个整体来处理,并且多次交互所涉及的数据(状态)保存下来,需要的朋友可以参考下
    2023-05-05

最新评论