Hibernate 기준 쿼리: 특정 열 선택
Hibernate 기준 쿼리에서 기본 동작은 지정된 테이블에서 모든 열을 검색하는 것입니다. 그러나 성능 최적화를 위해 쿼리 결과에서 특정 열을 제외할 수 있습니다.
열 선택을 위한 예측
쿼리 결과에서 열을 제외하려면 예측을 수행할 수 있습니다. 사용됩니다. 프로젝션을 사용하면 반환되어야 하는 속성 목록을 지정할 수 있습니다. 원하는 속성을 명시적으로 나열하면 나머지 열은 제외됩니다.
기준 쿼리 예
다음 SQL 쿼리를 고려하세요.
<code class="sql">SELECT user.id, user.name FROM user;</code>
Hibernate Criteria Query를 사용하여 동일한 결과를 얻으려면 다음 코드를 사용할 수 있습니다.
<code class="java">CriteriaBuilder cb = session.getCriteriaBuilder(); CriteriaQuery<Tuple> cq = cb.createTupleQuery(); Root<User> root = cq.from(User.class); cq.multiselect(root.get("id"), root.get("name"));</code>
이 예에서 cb, cq 및 root는 쿼리 구성을 용이하게 하는 빌더 개체입니다. multiselect() 메서드는 반환할 열을 지정하는 데 사용됩니다.
HQL에서 프로젝션 처리
위 기준 쿼리에 해당하는 HQL은 다음과 같습니다.
<code class="hql">SELECT id, name FROM User</code>
프로젝션을 사용하면 쿼리를 최적화하고 데이터베이스에서 검색되는 데이터의 양을 줄일 수 있습니다.
위 내용은 Hibernate 기준 쿼리에서 특정 열을 어떻게 선택합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!