Spring Boot JDBC 模板 SQL 日志

新手上路,请多包涵

我正在尝试使用 Spring Boot JDBC 的参数记录 SQL 查询,但它没有在日志中打印详细信息。我正在使用 Spring Boot 1.5.8 版本。请帮助我解决这个问题。

应用程序.properties:

 spring.datasource.url=url
spring.datasource.username=user
spring.datasource.password=password
spring.datasource.driver-class-name=com.microsoft.sqlserver.jdbc.SQLServerDriver

logging.level.org.springframework.jdbc.core.JdbcTemplate=debug

spring.datasource.type = com.zaxxer.hikari.HikariDataSource
spring.datasource.hikari.connection-timeout=60000
spring.datasource.hikari.maximum-pool-size=2

存储库:

 @Repository
public class DataRepository {
    private static Logger log = LoggerFactory.getLogger(DataRepository.class);

    @Autowired
    private NamedParameterJdbcTemplate jdbcTemplate;

    public Data findDataObjet() throws Exception {

        Map<String, Object> parameters = new HashMap<>();
        parameters.put("id1", "mike");
        parameters.put("id2", new Long(1));

        String sqlString = "select * from table1 where id1 = ":id" and id2 = :id2";
        log.info("Query:" + sqlString);//this log is printing

        Data extObj = jdbcTemplate.query(sqlString, parameters, (rs) -> {
            if (rs != null && rs.next()) {
                Data innerObj = new Data();
                innerObj.setName(rs.getString("name"));
                return innerObj;
            } else {
                log.info("No records found:"+rs);
                return null;
            }
        });

        return extObj;

    }
}

logback-spring.xml:

 <appender name="dailyRollingFileAppender"
    class="ch.qos.logback.core.rolling.RollingFileAppender">
    <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
        <FileNamePattern>${logsPath}DATA%d{MMddyyyy}.log
        </FileNamePattern>
        <maxHistory>4</maxHistory>
    </rollingPolicy>

    <encoder>
        <Pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level
            %logger{35}-%msg %n</Pattern>
    </encoder>
</appender>
<root level="INFO">
    <appender-ref ref="dailyRollingFileAppender" />
</root>

原文由 sunleo 发布,翻译遵循 CC BY-SA 4.0 许可协议

阅读 874
2 个回答

尝试

log4j.category.org.springframework.jdbc.core = TRACE

上面的语句也将打印带有入站参数的 SQL 查询。

如果您只需要记录查询,请使用以下内容

log4j.category.org.springframework.jdbc.core = DEBUG

您可以使用以下命令在您的 logback 文件中启用

<logger name="org.springframework.jdbc.core.JdbcTemplate">
  <level value="debug" />
</logger>

<logger name="org.springframework.jdbc.core.StatementCreatorUtils">
  <level value="debug" />
</logger>

更新: 对于 Springboot 2.x,它将是

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

感谢朱国伟!

原文由 CGS 发布,翻译遵循 CC BY-SA 4.0 许可协议

将以下内容添加到您的属性文件也可以:

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

原文由 Pouriya Zarbafian 发布,翻译遵循 CC BY-SA 4.0 许可协议

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题