springboot整合jpa 以及日志输出打印SQL语句和传入的参数

本文详细介绍了如何在SpringBoot项目中整合JPA,并配置日志打印SQL语句。通过添加相关依赖,配置YML文件,创建Entity、DAO、Service和Controller层,实现了数据操作。同时,通过引入log4jdbc-log4j2库,调整配置,成功实现了SQL日志的打印。最后,展示了控制台输出的查询结果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

先说springboot整合jpa

PA(java persistence api),它并不是一个框架,而是一组规范。其中,Hibernate就实现了这个规范,而且是相当成功的(其实TopLink和OpenJPA也都实现了JPA规范,不过它们被Hinernate的光环笼罩了)。所以呢,当我们说到JPA的时候,好多人首先想到的就是Hibernate。

一,创建工程时把依赖添加上

二,配置yml文件 

########springboot整合jpa配置
spring:
  devtools:
    restart:
      enabled: false
  datasource:
    driver-class-name: com.mysql.jdbc.Driver
    url: jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf-8&serverTimezone=GMT%2B8
    hikari: # springboot 2.0 整合了hikari ,据说这是目前性能最好的java数据库连接池
      username: root
      password: 123456
  jpa:
    hibernate:
      ddl-auto: update  # 第一次建表create  后面用update,要不然每次重启都会新建表
    show-sql: true
  logging:
    level:
      cn.com.lc.dao: debug #sql日志打印

三,工程目录,以及各个包下的类代码

1,entity包下的User  (使用jpa后自动创建表) 

import lombok.Data;

import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;

@Data
@Entity

public class User {
    @Id
    @GeneratedValue
    private long id;
    private String name;
}

2,dao包下的UserDao(继承JpaRepository接口后 有很多可用的方法可以拿来直接用 这里用findAll()方法测试) 

 

import com.lc.entity.User;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.stereotype.Component;

import java.util.List;

@Component
public interface UserDao extends JpaRepository<User, Long> {
    @Override
    List<User> findAllById(Iterable<Long> iterable);

    @Override
    List<User> findAll();
}

3,service包下的UserService接口

public interface UserService {
    List<User>findAll();
}

 实现类UserServiceImpl

@Service
public class UserServiceImpl implements UserService {
    @Autowired
    private UserDao userDao;

    @Override
    public List<User> findAll() {
        return userDao.findAll();
    }
}

4,controller包下的UserController

@RestController
public class UserController {
    @Autowired
    private UserService userService;

    @RequestMapping("/list")
    public List <User>findAll(){
        return userService.findAll();
    }
}

在浏览器输入:http://localhost:8055/list 验证

 

 

接下来开始配置打印sql日志:

在原有的pom.xml上加上这个依赖

        <!--监控sql日志-->
        <dependency>
            <groupId>org.bgee.log4jdbc-log4j2</groupId>
            <artifactId>log4jdbc-log4j2-jdbc4.1</artifactId>
            <version>1.16</version>
        </dependency>

 

 在resouce新增 log4jdbc.log4j2.properties 配置文件:

# If you use SLF4J. First, you need to tell log4jdbc-log4j2 that you want to use the SLF4J logger
log4jdbc.spylogdelegator.name=net.sf.log4jdbc.log.slf4j.Slf4jSpyLogDelegator

重新配置yml文件

#########Springboot JPA日志输出打印SQL语句和传入的参数 配置
#服务端口
server:
  port: 8055

spring:
  datasource:
    #    driver-class-name: com.mysql.cj.jdbc.Driver
    driver-class-name: net.sf.log4jdbc.sql.jdbcapi.DriverSpy
    #    url: jdbc:mysql://localhost:3306/test?useSSL=false&useUnicode=true&characterEncoding=UTF-8&serverTimezone=GMT%2B8&zeroDateTimeBehavior=convertToNull
    url: jdbc:log4jdbc:mysql://localhost:3306/test?useSSL=false&useUnicode=true&characterEncoding=UTF-8&serverTimezone=GMT%2B8&zeroDateTimeBehavior=convertToNull
    hikari: # springboot 2.0 整合了hikari ,据说这是目前性能最好的java数据库连接池
      username: root
      password: 123456
      minimum-idle: 5  # 最小空闲连接数量
      idle-timeout: 180000 # 空闲连接存活最大时间,默认600000(10分钟)
      maximum-pool-size: 10 # 连接池最大连接数,默认是10
      auto-commit: true # 此属性控制从池返回的连接的默认自动提交行为,默认值:true
      pool-name: MyHikariCP # 连接池名称
      max-lifetime: 1800000 # 此属性控制池中连接的最长生命周期,值0表示无限生命周期,默认1800000即30分钟
      connection-timeout: 30000 # 数据库连接超时时间,默认30秒,即30000
  #      connection-test-query: SELECT 1 #连接池每分配一条连接前执行的查询语句(如:SELECT 1),以验证该连接是否是有效的。如果你的驱动程序支持 JDBC4,HikariCP 强烈建议我们不要设置此属性

  jpa:
    hibernate:
      ddl-auto: update  #
    show-sql: true #
    database-platform: org.hibernate.dialect.MySQL5InnoDBDialect #设置数据库方言  记住必须要使用 MySQL5InnoDBDialect 指定数据库类型对应InnoDB  ;如果使用MySQLDialect 则对应的是MyISAM
  logging:
    level:
      cn.com.lc.dao: debug #sql日志打印


test-key: JCccc-test-key-one

添加上这个配置后,在查询sql语句的时候会打印sql语句

测试一下:http://localhost:8055/list

 控制台显示情况:

显示sql语句成功执行

显示这条sql语句成功执行

 控制台查询结果

到这就执行完成了,源码获取地址:https://github.com/wen521/springboot-jpa-sqlGenertaed

### 配置 Spring Boot 记录 SQL 执行情况 在 Spring Boot 应用程序中,可以通过多种方式配置日志以记录 SQL 语句的执行情况。以下是详细的说明: #### 使用默认日志框架(Logback) Spring Boot 默认集成了 Logback 作为其日志框架。为了启用 SQL 日志记录,可以调整 `application.properties` 或 `application.yml` 文件中的日志级别设置。 1. **针对 Hibernate 的 SQL 日志** 如果使用的是 Spring Data JPA Hibernate,则可以在 `application.properties` 中添加以下配置: ```properties logging.level.org.hibernate.SQL=debug logging.level.org.hibernate.type.descriptor.sql.BasicBinder=trace ``` 上述配置分别启用了 SQL 查询的日志记录绑定参数日志记录[^1]。 2. **针对 MyBatisSQL 日志** 对于基于 MyBatis 的项目,同样可以通过修改日志级别来实现 SQL 输出的功能。具体来说,在 `application.properties` 中加入如下内容即可: ```properties logging.level.com.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor=debug ``` 此外,如果希望进一步增强对数据库操作细节的理解,还可以引入 Druid 数据源并为其单独定义 logger: ```xml <logger name="druid.sql.Statement" level="DEBUG" additivity="false"/> ``` 这一 XML 片段应被追加至项目的 `logback-spring.xml` 文件之中[^5]。 3. **自定义 Logger 设置** 当上述通用方法无法满足特定需求时,可考虑创建专属的日志类别或者利用 AOP 技术拦截目标服务层函数调用链路从而完成更加精细的操作跟踪[^2]。 4. **验证效果** 完成以上更改之后重新运行您的 springboot 工程,此时终端应该能够展示出每次访问数据表所对应的原始 sql 文本连同实际传入变量值一同呈现出来便于排查问题所在之处[^4]。 ```java // 示例:测试类用于确认日志输出正常工作的简单例子 @SpringBootTest public class SqlLoggingTest { @Autowired private YourRepository repository; @Test void testSqlLogs() { List<YourEntity> entities = repository.findAll(); assertNotNull(entities); } } ```
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

梁晨le

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值