请教一下 Mybatis Mapper SQL

32 天前
 hejw19970413

最近小弟在公司的要求下把项目的 SQL 适配到其他数据库上。 之前没搞过 Java,听同事稍微的讲了一下。 经了解项目是 SQL 用 MyBatis ,现在项目下有好多的 Mapper.xml 的 SQL 模板文件。 请问大家这 Mapper 怎么能把生成出来的 SQL 打印出来。 有什么好的办法我想学习一下

1308 次点击
所在节点    程序员
15 条回复
liuzhedash
32 天前
简单版:

配置里面加
mybatis-plus.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl
可以打印出 sql 模板和参数

复杂版:
https://github.com/p6spy/p6spy
qq135449773
32 天前
设置 mapper package 的 log level 为 debug
wymisgod
32 天前
看你们使用的什么日志实现。因为 Log4j 有安全漏洞,所以大概是三四年前之后,基本上都让换成 logback+slf4j 的日志打印方式了。
这里又有分叉,一个是 logback 配置里没有配置日志打印 level 的,这个的话一般在 application.yml 或者 application.properties 里可以设置。
另外一种是在 logback-spring.xml 里进行配置。这里又有分叉了,好多种可以修改打印日志级别的情况,说两个比较常规的,一个在该文件里找<appender>标签里包含 ch.qos.logback.core.ConsoleAppender 或者带 console 的,去看日志打印级别是否是 INFO ,修改为 DEBUG 即可。一个是<root>标签里的打印级别。
还有一种情况就是 mybatis 配置的日志实现
hejw19970413
32 天前
其实我是想直接把 SQL 给弄出来,不想去执行,因为还有一个要求是写个文档,领导要看,我要是执行的来说,里面有好多的判断啥的,得处理好多得查询条件。
@wymisgod
@liuzhedash
@qq135449773
wymisgod
32 天前
@hejw19970413 初始开发人员不维护文档,现在想起来了要整,让你来维护,给领导说干不了。看这情况,估计 DDL 的上线应该也没有审核机制,早点跑
tpeng9240
32 天前
Akitora
32 天前
环境变量设置 logging.level.xxx.mapper=DEBUG
lpe234
31 天前
cobbage
31 天前
xml 里面不就是 sql ,除了参数条件
billccn
31 天前
既然用了 Mybatis 估计不是纯粹运行简单 SQL 而是至少有一些动态 SQL ,你也不运行代码的情况下是无法自动打出所有可能的 SQL 的,否则就是解决了 halting problem ,要不你把 Mapper.xml 人工分析一下。
xuanbg
31 天前
别想着打出完整的 SQL 语句。里面肯定有<if ...>xxx</if>之类的,条件不匹配就不会拼进 SQL 去执行,也就打不出来这部分查询条件。

正确的做法还是学一下 xml 的写法,其实挺简单的。学会了再把 xml 翻译成 SQL 。
LiaoMatt
31 天前
写个 Mybatis 拦截器, 执行前打印 SQL
hejw19970413
31 天前
@lpe234 这两个项目我试过了,解析不出来
montaro2017
31 天前
IDEA 有个 Mybatis Log Free 插件 https://plugins.jetbrains.com/plugin/17898-mybatis-log-free
启用后可以查看到完整的 SQL
montaro2017
31 天前
@montaro2017 #14 要先开启 mybatis 的日志打印功能才有用

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/1092440

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX