环境说明:IntelliJ IDEA 2017.3.4 版本;SpringBoot 2.0.0.RELEASE;hibernate用的是JPA自带。
打印SQL 到控制台:
首先,我使用的是application.properties配置文件,使用yml也可以达到同样的效果。
在网上查这个问题查了好久,基本上都是xml配置,在此不多说;
正确的properties配置项应该如下图所示:
在jpa下一级不直接是hibernate,而是properties。
spring.jpa.properties.hibernate.show_sql=true //控制台是否打印
spring.jpa.properties.hibernate.format_sql=true //格式化sql语句
spring.jpa.properties.hibernate.use_sql_comments=true //指出是什么操作生成了该语句
此时,在控制台看到的现象:Hibernate:
可以看到,控制台打印了一条经过格式化之后的sql语句,并标明了这条语句是在Hibernate插入TaskWebSiteRev这个对象到数据库的时候生成的。
打印SQL参数到控制台
经过上面的步骤,我们已经可以在控制台打印出格式化之后的sql语句,但是大多数情况下,我们还需要具体的sql参数值,这个时候我们就需要配置 日志配置文件。
博主使用的是slf4j的日志,配置文件用的是logback.xml,配置方式如下:
<logger name="org.hibernate.S