Hibernate 기준 쿼리에서 특정 열을 어떻게 선택합니까?

Mary-Kate Olsen
풀어 주다: 2024-10-26 08:29:30
원래의
806명이 탐색했습니다.

How Do I Select Specific Columns in Hibernate Criteria Queries?

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿