>데이터 베이스 >MySQL 튜토리얼 >내 Hibernate SQL 쿼리에서 실제 매개변수 값을 어떻게 볼 수 있습니까?

내 Hibernate SQL 쿼리에서 실제 매개변수 값을 어떻게 볼 수 있습니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2025-01-22 22:25:13876검색

How Can I See the Real Parameter Values in My Hibernate SQL Queries?

Hibernate SQL 쿼리 매개변수 값 조회 방법

Hibernate로 쿼리를 실행할 때 데이터베이스에 전달된 실제 매개변수 값을 확인하는 것이 유용한 경우가 많습니다.

Hibernate가 실제 매개변수 값을 직접 표시할 수 있나요?

안타깝게도 Hibernate 자체에서는 실제 매개변수 값이 포함된 SQL 쿼리를 직접 인쇄하는 메커니즘을 제공하지 않습니다. SQL 문의 물음표는 플레이스홀더 매개변수를 나타내며, Hibernate는 자동으로 이를 실제 매개변수 값으로 대체하지 않습니다.

로깅 대안

매개변수 값이 포함된 실제 SQL 쿼리 문자열을 보려면 특정 Hibernate 클래스에 대한 로깅을 활성화할 수 있습니다.

  • org.hibernate.SQL: 실행된 모든 SQL DML 문을 기록하려면 "debug"로 설정합니다.
  • org.hibernate.type: 모든 JDBC 매개변수를 기록하려면 "trace"로 설정합니다.

다음 log4j 구성은 이 접근 방식을 보여줍니다.

<code>log4j.logger.org.hibernate.SQL=debug

# 记录传递给查询的JDBC参数
log4j.logger.org.hibernate.type=trace</code>

이 방법은 이전 hibernate.show_sql=true 속성과 유사합니다. org.hibernate.type 로깅을 활성화하면 바인딩 매개변수를 포함하여 더 많은 정보가 기록된다는 점은 주목할 가치가 있습니다.

외부 프록시 드라이버

또 다른 방법은 P6Spy와 같은 JDBC 프록시 드라이버를 사용하는 것입니다. P6Spy는 JDBC 호출을 가로채서 데이터베이스로 전송된 실제 SQL 쿼리와 매개변수 값을 검사할 수 있도록 해줍니다.

위 내용은 내 Hibernate SQL 쿼리에서 실제 매개변수 값을 어떻게 볼 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.