Spring Data JPA显示SQL,Spring Data JPA在控制台打印执行的SQL语句

在配置文件中添加配置:spring.jpa.show-sql=true

如果像下图的写法,记得在:(冒号)后面加空格。

运行是可以看到控制台输出的SQL语句。

 

 

### Spring Data JPA 的概念 Spring Data JPASpring Data 家族的一部分,旨在简化数据访问层的开发工作。它通过提供一组通用接口和抽象类,使得开发者能够专注于业务逻辑而无需编写繁琐的数据访问代码。核心组件包括 `CrudRepository` 和 `JpaRepository` 接口,它们提供了诸如增删改查等常用操作的支持[^1]。 例如定义一个简单的 Repository 如下所示: ```java public interface UserRepository extends JpaRepository<User, Long> { List<User> findByName(String name); } ``` 上述例子中,除了继承自 `JpaRepository` 提供的基础 CRUD 方法外,还声明了一个基于方法名解析机制动态构建查询的方法 `findByName`[^2]。 --- ### 配置 Hibernate 显示明文 SQL 插入语句 为了让 Hibernate 在控制台打印出带有实际参数值而非占位符 (`?`) 的明文 SQL 插入语句,可按照以下步骤进行配置: #### 1. **启用基本 SQL 日志** 在项目的 `application.properties` 或 `application.yml` 文件中开启 Hibernate 的 SQL 打印功能。例如,在 `.properties` 文件中添加如下内容: ```properties spring.jpa.show-sql=true spring.jpa.properties.hibernate.format_sql=true ``` 这两项分别用于打开 SQL 输出开关以及美化输出格式[^3]。 #### 2. **调整日志级别以展示参数细节** 仅靠以上设置还不足以显示真正的参数值,还需要进一步调节日志系统的敏感度。如果项目采用的是 Logback,则可在其配置文件(通常是 `logback.xml`)里加入下面的内容: ```xml <logger name="org.hibernate.SQL" level="DEBUG"/> <logger name="org.hibernate.type.descriptor.sql.BasicBinder" level="TRACE"/> ``` 其中: - `org.hibernate.SQL`: 记录所有的 HQL/SQL 语句。 - `org.hibernate.type.descriptor.sql.BasicBinder`: 展现绑定到这些语句上的变量的实际值[^4]。 最终的效果将是类似于这样的输出: ```sql insert into user (name, age) values ('John Doe', 30) ``` 这表明不仅能看到完整的插入命令,还能清楚知晓每条记录的具体字段及其对应值[^5]。 --- ###
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值