Hibernate Criteria API는 복잡한 쿼리를 이해하기 쉬운 형식으로 표현하기 위한 강력한 도구입니다. 그러나 실제 실행된 SQL을 검색하는 직접적인 방법은 제공하지 않습니다. 이는 원시 SQL이 필요한 외부 시스템과 디버깅 또는 통합을 위해 정확한 SQL 쿼리에 액세스해야 할 때 문제가 될 수 있습니다.
이 문제를 해결하려면 다음을 사용하여 Hibernate Criteria에서 기본 SQL을 가져올 수 있습니다.
<code class="language-java">CriteriaImpl criteriaImpl = (CriteriaImpl)criteria; SessionImplementor session = criteriaImpl.getSession(); SessionFactoryImplementor factory = session.getFactory(); CriteriaQueryTranslator translator = new CriteriaQueryTranslator(factory, criteriaImpl, criteriaImpl.getEntityOrClassName(), CriteriaQueryTranslator.ROOT_SQL_ALIAS); String[] implementors = factory.getImplementors(criteriaImpl.getEntityOrClassName()); CriteriaJoinWalker walker = new CriteriaJoinWalker((OuterJoinLoadable)factory.getEntityPersister(implementors[0]), translator, factory, criteriaImpl, criteriaImpl.getEntityOrClassName(), session.getLoadQueryInfluencers()); String sql = walker.getSQLString();</code>
이 코드:
이 방법을 사용하면 Hibernate Criteria가 실행할 SQL 쿼리에 대한 액세스를 제공하여 문제 해결, 로그 디버그 또는 원시 SQL이 필요한 외부 시스템과의 통합이 가능해집니다.
위 내용은 Hibernate 기준 객체에서 기본 SQL 쿼리를 어떻게 검색할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!