Hibernate를 사용하여 페이징 쿼리 구현
예:
20,000번째 레코드부터 100개의 레코드 검색
코드:
Query q = session.createQuery("from Cat as c");
q.setFirstResult (20000);
q.setMaxResults(100);
List l = q.list();
그러면 Hibernate의 최하위 계층은 어떻게 페이징을 구현합니까? 실제로 Hibernate의 쿼리는 net.sf.hibernate.loader.Loader 클래스에 정의되어 있습니다. 이 클래스의 코드를 주의 깊게 읽어보면 문제를 완전히 이해할 수 있습니다.
Hibernate2.0.3의 Loader 소스 코드 480번째 줄은 다음과 같습니다.
코드:
if (useLimit) sql = Dialect.getLimitString(sql)
ReadyStatement st; = session.getBatcher().prepareQueryStatement(sql,
scrollable);
해당 데이터베이스에서 쿼리 레코드를 제한하는 sql 문을 정의하는 경우 해당 데이터베이스의 sql 문을 직접 사용하세요. StringBuffer pagingSelect = new StringBuffer(100);
pagingSelect.append(sql);
pagingSelect.append(" 제한 ?, ?");
pagingSelect를 반환합니다. toString (); {
return true;
public String getLimitString(String sql) {
StringBuffer pagingSelect = new StringBuffer(100);
row_.*, rownum rownum_
from ( ") ;
pagingSelect.append(sql);
pagingSelect.append(" ) row_ where rownum <= ?) where rownum_ > ?");
return pagingSelect.toString(); 레이어의 쿼리 문은 정렬 기준을 지원할 수 없습니다.
이외에도 Interbase, PostgreSQL, HSQL도 Paging SQL 문을 지원하며 해당 Dialect에서 참고할 수 있습니다.
데이터베이스가 페이징 SQL 문을 지원하지 않으면 구성 파일의 #hibernate.jdbc.use_scrollable_resultset true에 따라 false를 지정하지 않으면 Hibernate는 스크롤 가능 결과를 사용합니다. JDBC2.0에서 페이지 매김을 구현하려면 Loader의 다음 430행을 살펴보세요.
코드:
if ( session.getFactory().useScrollableResultSets() ) {
// 할 수 있습니다. 첫 번째 필수 행으로 바로 이동
rs.absolute(firstRow);
}
else {
// 한 번에 한 행씩 진행해야 합니다(느림)
for ( int m=0; m
스크롤 가능한 결과를 지원하는 경우 ResultSet의 절대 메소드를 사용하여 쿼리 시작점으로 직접 이동 그렇지 않은 경우 루프 문과 rs.next를 사용하여 비트 단위로 이동합니다.
Hibernate를 사용하면 쿼리 및 페이징 작업에 큰 유연성이 있음을 알 수 있습니다. Hibernate는 먼저 특정 데이터베이스의 페이징 SQL을 사용하려고 시도하고 작동하지 않으면 Scrollable을 시도합니다. 마지막으로 rset.next() 이동 방법을 사용합니다.
쿼리 페이징 코드에서 Hibernate를 사용하는 가장 큰 이점 중 하나는 쿼리 페이징 성능을 고려할 뿐만 아니라 서로 다른 데이터베이스 간의 코드 이식성을 보장한다는 것입니다.

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











SpringBoot 프로젝트 서문에 Hibernate 통합하기 Hibernate는 지속성 작업을 용이하게 하기 위해 Java 객체를 데이터베이스 테이블에 매핑할 수 있는 널리 사용되는 ORM(Object Relational Mapping) 프레임워크입니다. SpringBoot 프로젝트에서 Hibernate를 통합하면 데이터베이스 작업을 더 쉽게 수행하는 데 도움이 될 수 있습니다. 이 기사에서는 SpringBoot 프로젝트에 Hibernate를 통합하는 방법을 소개하고 해당 예제를 제공합니다. 1.종속성 소개pom.xml 파일에 다음 종속성을 소개합니다: org.springframework.bootspring-boot-starter-data-jpam

Java는 소프트웨어 개발 분야에서 널리 사용되는 객체 지향 프로그래밍 언어입니다. Hibernate는 Java 객체의 지속성을 관리하는 간단하고 효율적인 방법을 제공하는 인기 있는 Java 지속성 프레임워크입니다. 그러나 개발 과정에서 Hibernate 오류가 자주 발생하며, 이러한 오류로 인해 프로그램이 비정상적으로 종료되거나 불안정해질 수 있습니다. Hibernate 오류를 처리하고 방지하는 방법은 Java 개발자가 숙달해야 하는 기술이 되었습니다. 이 기사에서는 몇 가지 일반적인 Hib를 소개합니다.

최대 절전 모드와 mybatis의 차이점: 1. 구현 방법 2. 성능 3. 개체 관리 비교 4. 캐싱 메커니즘 자세한 소개: 1. 구현 방법인 Hibernate는 객체를 데이터베이스 테이블에 매핑하는 완전한 객체/관계형 매핑 솔루션인 반면, MyBatis는 개발자가 SQL 문과 ResultMap을 수동으로 작성해야 합니다. 2. 성능, Hibernate는 개발 속도 측면에서 가능합니다. MyBatis는 Hibernate가 DAO 레이어 등을 단순화하기 때문입니다.

이 기사에서는 Hibernate에서 대량 삽입/업데이트를 수행하는 방법을 살펴보겠습니다. SQL 문을 실행할 때마다 데이터베이스에 대한 네트워크 호출을 통해 이를 수행합니다. 이제 데이터베이스 테이블에 10개의 항목을 삽입해야 한다면 10개의 네트워크 호출을 수행해야 합니다. 대신 일괄 처리를 사용하여 네트워크 호출을 최적화할 수 있습니다. 일괄 처리를 통해 단일 네트워크 호출에서 일련의 SQL 문을 실행할 수 있습니다. 이를 이해하고 구현하기 위해 엔터티를 정의해 보겠습니다. @EntitypublicclassParent{@Id@GeneratedValue(strategy=GenerationType.AUTO)

Hibernate의 일대다 및 다대다 Hibernate는 Java 애플리케이션과 관계형 데이터베이스 간의 데이터 액세스를 단순화하는 탁월한 ORM 프레임워크입니다. Hibernate에서는 복잡한 데이터 모델을 처리하기 위해 일대다 및 다대다 관계를 사용할 수 있습니다. Hibernate의 일대다 Hibernate에서 일대다 관계는 하나의 엔터티 클래스가 여러 개의 다른 엔터티 클래스에 대응한다는 것을 의미합니다. 예를 들어, 하나의 주문은 여러 주문 항목(OrderItem)에 해당할 수 있고, 사용자(User)는 여러 주문(Order)에 해당할 수 있습니다. Hibernate에서 일대다 관계를 구현하려면, 저장할 엔터티 클래스에 컬렉션 속성을 정의해야 합니다.

Java 프레임워크 기술 스택: SpringMVC, Hibernate, MyBatis 등 일반적으로 사용되는 Java 프레임워크를 소개합니다. Java가 지속적으로 개발됨에 따라 개발 프로세스를 단순화하기 위해 점점 더 많은 프레임워크가 개발되었습니다. 그 중 SpringMVC, Hibernate, MyBatis 등은 Java 개발에서 가장 일반적으로 사용되는 프레임워크 중 하나입니다. 이 기사에서는 독자가 이러한 프레임워크를 더 잘 이해하고 적용할 수 있도록 이러한 프레임워크의 기본 개념과 사용법을 소개합니다. 먼저 Sp를 소개하겠습니다.

Hibernate는 관계형 데이터베이스와 Java 프로그램 간의 데이터 매핑을 서로 바인딩하여 개발자가 데이터베이스의 데이터에 더 쉽게 액세스할 수 있도록 하는 오픈 소스 ORM 프레임워크입니다. Hibernate 프레임워크를 사용하면 SQL 문 작성 작업이 크게 줄어들고 애플리케이션의 개발 효율성과 재사용성이 향상됩니다. 다음과 같은 측면에서 Hibernate 프레임워크를 소개해보자. 1. Hibernate 프레임워크의 장점: 객체-관계형 매핑, 데이터베이스 액세스 세부 사항 숨기기, 개발 수행

캐싱은 쿼리를 실행할 때 데이터베이스 네트워크 호출을 줄이는 데 도움이 됩니다. 레벨 1 캐시 및 세션 연결. 암시적으로 구현됩니다. 첫 번째 수준 캐시는 세션 개체가 존재할 때까지 존재합니다. 세션 개체가 종료되거나 닫히면 캐시된 개체가 없습니다. 두 번째 수준 캐시는 여러 세션 개체에 대해 작동합니다. 세션 팩토리와 연결되어 있습니다. 두 번째 수준 캐시 개체는 단일 세션 팩터리를 사용하는 모든 세션에서 사용할 수 있습니다. 이러한 캐시 개체는 특정 세션 팩토리가 닫힐 때 종료됩니다. 두 번째 수준 캐시를 구현하려면 두 번째 수준 캐시를 사용하기 위해 다음 종속성을 추가해야 합니다. <!--https://mvnrepository.com/artifact/net.sf.ehcache/ehcache--><de
