在Spring Boot內建Mybatis的項目中,如果出現SQL語句執行問題,我們需要進行排查。此時就需要列印對應的SQL語句,那麼該如何操作才能正常列印出對應的SQL語句呢?
其實操作非常簡單,在application.properties或application.yml檔案中配置對應mapper所在包的日志級别即可。
示例如下:
logging.level.com.secbro.mapper=debug
複制
其中“logging.level.”為字首,“com.secbro.mapper”為Mapper接口所在的包路徑。對應的value值為日志的級别。
此時,再執行查詢程式,就會列印出對應的SQL日志資訊來。
對應的Mapper檔案比如:
package com.secbro.mapper;
import com.secbro.model.Order;
import org.apache.ibatis.annotations.*;
import java.util.List;
/**
* @author sec
* @version 1.0
* @date 2020/3/1 10:01 AM
**/
public interface OrderMapper {
/**
* 更新訂單
*
* @param order 訂單資訊
* @return 記錄數
*/
@Update("UPDATE tb_order SET order_no = #{orderNo},amount = #{amount} WHERE id =#{id}")
int update(Order order);
}
複制
注意package的路徑對照。
添加debug列印之後,執行一條單元測試,對應的日志資訊如下:
2020-04-02 21:43:39.466 INFO 92784 --- [ main] com.zaxxer.hikari.HikariDataSource : HikariPool-1 - Starting...
2020-04-02 21:43:39.869 INFO 92784 --- [ main] com.zaxxer.hikari.HikariDataSource : HikariPool-1 - Start completed.
2020-04-02 21:43:39.881 DEBUG 92784 --- [ main] com.secbro.mapper.OrderMapper.update : ==> Preparing: UPDATE tb_order SET order_no = ?,amount = ? WHERE id =?
2020-04-02 21:43:39.917 DEBUG 92784 --- [ main] com.secbro.mapper.OrderMapper.update : ==> Parameters: N001(String), 8888(Integer), 1(Integer)
2020-04-02 21:43:39.921 DEBUG 92784 --- [ main] com.secbro.mapper.OrderMapper.update : <== Updates: 1
2020-04-02 21:43:39.939 INFO 92784 --- [extShutdownHook] o.s.s.concurrent.ThreadPoolTaskExecutor : Shutting down ExecutorService 'applicationTaskExecutor'
2020-04-02 21:43:39.940 INFO 92784 --- [extShutdownHook] com.zaxxer.hikari.HikariDataSource : HikariPool-1 - Shutdown initiated...
2020-04-02 21:43:39.949 INFO 92784 --- [extShutdownHook] com.zaxxer.hikari.HikariDataSource : HikariPool-1 - Shutdown completed.
複制
其中,我們可以很清楚的看到對應的SQL語句,參數以及執行結果。
精品SpringBoot 2.x視訊教程
《Spring Boot 2.x 視訊教程全家桶》,精品Spring Boot 2.x視訊教程,打造一套最全的Spring Boot 2.x視訊教程