Hibernate 기준 쿼리를 사용하여 특정 열 검색
도전 과제:
Hibernate 기준 쿼리에서 , 특히 대규모 이진 데이터가 포함된 경우 개발자가 테이블에서 모든 열을 선택할 때 성능 문제가 발생하는 것이 일반적입니다. 목표는 쿼리에서 특정 열을 제외하여 성능을 향상시키는 것입니다.
해결책: 프로젝션 쿼리
이 문제를 극복하기 위해 Hibernate는 프로젝션을 제공합니다. 검색하려는 열. 프로젝션을 사용하면 쿼리에서 문제가 있는 열을 제외할 수 있어 쿼리 효율이 더욱 높아집니다.
예:
검색하는 다음 SQL 쿼리를 고려해 보세요. "사용자" 테이블의 모든 열:
<code class="sql">SELECT user.id, user.name FROM user;</code>
프로젝션을 사용하여 이 쿼리를 Hibernate 기준 쿼리로 변환하려면 다음 코드를 사용할 수 있습니다.
<code class="java">Criteria cr = session.createCriteria(User.class) .setProjection(Projections.projectionList() .add(Projections.property("id"), "id") .add(Projections.property("Name"), "Name")) .setResultTransformer(Transformers.aliasToBean(User.class)); List<User> list = cr.list();</code>
이 코드에서, 투영을 생성하고 여기에 원하는 열을 추가합니다. 그런 다음 프로젝션을 Criteria 개체로 설정하여 지정된 열만 결과 집합에 반환되도록 합니다.
Where 절 오류 처리:
업데이트된 쿼리에서 , 프로젝션을 사용할 때 "where" 절에 오류가 발생했습니다. 이 문제를 해결하려면 쿼리 매개변수에 대해 매개변수화된 값을 사용해야 합니다. 예:
<code class="java">Criteria cr = session.createCriteria(User.class) .setProjection(Projections.projectionList() .add(Projections.property("id"), "id") .add(Projections.property("Name"), "Name")) .add(Restrictions.eq("STATUS_CODE", 1)) .add(Restrictions.eq("PRACTICE_ID", 1)) .add(Restrictions.in("USER_ID", Arrays.asList(1, 2))) .setResultTransformer(Transformers.aliasToBean(User.class));</code>
매개변수화된 값을 사용하여 Hibernate는 "where" 절에서 오류가 발생하지 않고 올바른 SQL 쿼리를 생성합니다.
위 내용은 대용량 바이너리 데이터 검색을 방지하고 성능을 향상시키기 위해 Hibernate Criteria Queries를 어떻게 최적화할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!