最近小弟在公司的要求下把项目的 SQL 适配到其他数据库上。 之前没搞过 Java,听同事稍微的讲了一下。 经了解项目是 SQL 用 MyBatis ,现在项目下有好多的 Mapper.xml 的 SQL 模板文件。 请问大家这 Mapper 怎么能把生成出来的 SQL 打印出来。 有什么好的办法我想学习一下
1
liuzhedash 31 天前
简单版:
配置里面加 mybatis-plus.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl 可以打印出 sql 模板和参数 复杂版: https://github.com/p6spy/p6spy |
2
qq135449773 31 天前
设置 mapper package 的 log level 为 debug
|
3
wymisgod 31 天前
看你们使用的什么日志实现。因为 Log4j 有安全漏洞,所以大概是三四年前之后,基本上都让换成 logback+slf4j 的日志打印方式了。
这里又有分叉,一个是 logback 配置里没有配置日志打印 level 的,这个的话一般在 application.yml 或者 application.properties 里可以设置。 另外一种是在 logback-spring.xml 里进行配置。这里又有分叉了,好多种可以修改打印日志级别的情况,说两个比较常规的,一个在该文件里找<appender>标签里包含 ch.qos.logback.core.ConsoleAppender 或者带 console 的,去看日志打印级别是否是 INFO ,修改为 DEBUG 即可。一个是<root>标签里的打印级别。 还有一种情况就是 mybatis 配置的日志实现 |
4
hejw19970413 OP 其实我是想直接把 SQL 给弄出来,不想去执行,因为还有一个要求是写个文档,领导要看,我要是执行的来说,里面有好多的判断啥的,得处理好多得查询条件。
@wymisgod @liuzhedash @qq135449773 |
5
wymisgod 31 天前
@hejw19970413 初始开发人员不维护文档,现在想起来了要整,让你来维护,给领导说干不了。看这情况,估计 DDL 的上线应该也没有审核机制,早点跑
|
7
Akitora 31 天前 via Android
环境变量设置 logging.level.xxx.mapper=DEBUG
|
8
lpe234 31 天前
|
9
cobbage 31 天前 via Android
xml 里面不就是 sql ,除了参数条件
|
10
billccn 31 天前
既然用了 Mybatis 估计不是纯粹运行简单 SQL 而是至少有一些动态 SQL ,你也不运行代码的情况下是无法自动打出所有可能的 SQL 的,否则就是解决了 halting problem ,要不你把 Mapper.xml 人工分析一下。
|
11
xuanbg 30 天前
别想着打出完整的 SQL 语句。里面肯定有<if ...>xxx</if>之类的,条件不匹配就不会拼进 SQL 去执行,也就打不出来这部分查询条件。
正确的做法还是学一下 xml 的写法,其实挺简单的。学会了再把 xml 翻译成 SQL 。 |
12
LiaoMatt 30 天前
写个 Mybatis 拦截器, 执行前打印 SQL
|
13
hejw19970413 OP @lpe234 这两个项目我试过了,解析不出来
|
14
montaro2017 30 天前
IDEA 有个 Mybatis Log Free 插件 https://plugins.jetbrains.com/plugin/17898-mybatis-log-free
启用后可以查看到完整的 SQL |
15
montaro2017 30 天前
@montaro2017 #14 要先开启 mybatis 的日志打印功能才有用
|