java - 如何在 Spring JDBC 中启用 sql 查询控制台日志记录

标签 java spring prepared-statement spring-jdbc

我是准备好的语句的新手,我正在尝试使用 jdbcTemplate 来使用基本插入和更新,这也工作正常,但我希望在控制台中打印 sql 查询的日志,但我不知道如何实现这一点。我已在 application.properties 文件中添加了必需的属性,但它不起作用。请通过提供一些适当的建议或引用链接来帮助我,这可能会解决我的问题。提前致谢...

示例配置.java

@Configuration
public class SampleConfiguration 
{
    @Bean
    public DataSource mysqlDataSource() 
    {
        DriverManagerDataSource dataSource = new DriverManagerDataSource();
        dataSource.setDriverClassName("org.hsqldb.jdbcDriver");
        dataSource.setUrl("jdbc:hsqldb:hsql://localhost/");
        dataSource.setUsername("SA");
        dataSource.setPassword(""); 
        return dataSource;
    }

    @Bean
    public JdbcTemplate jdbcTemplate(DataSource dataSource)
    {
        JdbcTemplate jdbcTemplate = new JdbcTemplate();
        jdbcTemplate.setDataSource(dataSource);
        return jdbcTemplate;
    }

}

SampleService.java

@Service
public interface SampleService 
{
    public int insert();
    public long getCount();
}

SampleServiceImpl.java

@Service
public class SampleServiceImpl implements SampleService 
{

    @Autowired
    JdbcTemplate jdbcTemplate;

    @Override
    public int insert()
    {
        return jdbcTemplate.update("insert into batch values(?,?)","field1","field2");
    }

    @Override
    public long getCount()
    {
        return jdbcTemplate.queryForObject("select count(*) from batch", Long.class);
    }

}

SpringjdbcApplication.java

@SpringBootApplication
public class SpringjdbcApplication 
{
    public static void main(String[] args) 
    {
        ApplicationContext context  = SpringApplication.run(SpringjdbcApplication.class, args);
        SampleService service = context.getBean(SampleService.class);
        System.err.println("The number of rows inserted = "+service.insert());
        System.err.println("The count of batch class is = "+service.getCount());
    }

}

实体.java

@Entity
public class Batch implements Serializable 
{

    private static final long serialVersionUID = -5687736664713755991L;

    @Id
    @Column(name="field1")
    private String field1;

    @Column(name="field2")
    private String field2;

        ... getter, setter and no-arg constructor
}

应用程序属性

spring.jpa.show-sql=true
spring.jpa.hibernate.ddl-auto=none
spring.jpa.properties.hibernate.format_sql=true

logging.level.org.hibernate.SQL=debug
logging.level.org.hibernate.type.descriptor.sql=trace

pom.xml

           <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-jpa</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-jdbc</artifactId>
        </dependency>
        <dependency>
            <groupId>org.hsqldb</groupId>
            <artifactId>hsqldb</artifactId>
            <scope>runtime</scope>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>

我想知道如何在控制台上打开 sql 语句日志记录以及如何设置其他属性,例如关闭或打开自动提交???

最佳答案

您应该将其添加到属性文件中

logging.level.org.springframework.jdbc.core = TRACE

这将启用 Spring Jdbc 日志

关于java - 如何在 Spring JDBC 中启用 sql 查询控制台日志记录,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56517599/

相关文章:

java - 如何从 JTextField 读取 int 值?

Java 迭代队列何时是类的成员

java - 在 org.springframework.web.context.ContextLoaderListener 中使用 Spring 启动 Tomcat 服务器

php - PDOStatement::execute 中的 PDO::PARAM_INT

Java 准备好的语句未输入数据并命中捕获

java - 如何让用户三次尝试输入正确的密码?

java - infinispan 配置 xml 错误

spring - Angular HTTP POST 请求

java - 使用点符号的 Thymeleaf 3 map 访问

php - mysqli_fetch_assoc()需要参数/调用成员函数bind_param()错误。如何获取并修复实际的mysql错误?