Hibernate-쿼리 언어
Hibernate Query Language (HQL)는 SQL과 유사한 객체 지향 쿼리 언어이지만 테이블과 열에서 작동하는 대신 HQL은 영구 객체 및 해당 속성과 함께 작동합니다. HQL 쿼리는 Hibernate에 의해 기존의 SQL 쿼리로 변환되어 데이터베이스에 대한 작업을 수행합니다.
Native SQL을 사용하여 Hibernate에서 SQL 문을 직접 사용할 수 있지만 데이터베이스 이식성 문제를 피하고 Hibernate의 SQL 생성 및 캐싱 전략을 활용하기 위해 가능하면 HQL을 사용하는 것이 좋습니다.
SELECT, FROM 및 WHERE 등과 같은 키워드는 대소 문자를 구분하지 않지만 테이블 및 열 이름과 같은 속성은 HQL에서 대소 문자를 구분합니다.
FROM 절
당신은 사용할 것입니다 FROM완전한 영구 객체를 메모리에로드하려는 경우 절. 다음은 FROM 절을 사용하는 간단한 구문입니다.
String hql = "FROM Employee";
Query query = session.createQuery(hql);
List results = query.list();
HQL에서 클래스 이름을 정규화해야하는 경우 다음과 같이 패키지와 클래스 이름을 지정하십시오.
String hql = "FROM com.hibernatebook.criteria.Employee";
Query query = session.createQuery(hql);
List results = query.list();
AS 조항
그만큼 AS절은 특히 긴 쿼리가있는 경우 HQL 쿼리의 클래스에 별칭을 할당하는 데 사용할 수 있습니다. 예를 들어, 이전의 간단한 예는 다음과 같습니다.
String hql = "FROM Employee AS E";
Query query = session.createQuery(hql);
List results = query.list();
그만큼 AS 키워드는 선택 사항이며 다음과 같이 클래스 이름 바로 뒤에 별칭을 지정할 수도 있습니다.
String hql = "FROM Employee E";
Query query = session.createQuery(hql);
List results = query.list();
SELECT 절
그만큼 SELECT절은 from 절보다 결과 집합에 대한 더 많은 제어를 제공합니다. 완전한 객체 대신 객체의 속성을 거의 얻지 않으려면 SELECT 절을 사용하십시오. 다음은 Employee 개체의 first_name 필드를 얻기 위해 SELECT 절을 사용하는 간단한 구문입니다-
String hql = "SELECT E.firstName FROM Employee E";
Query query = session.createQuery(hql);
List results = query.list();
여기서 주목할만한 것은 Employee.firstName EMPLOYEE 테이블의 필드가 아니라 Employee 개체의 속성입니다.
WHERE 절
저장소에서 반환되는 특정 개체의 범위를 좁히려면 WHERE 절을 사용합니다. 다음은 WHERE 절을 사용하는 간단한 구문입니다-
String hql = "FROM Employee E WHERE E.id = 10";
Query query = session.createQuery(hql);
List results = query.list();
ORDER BY 절
HQL 쿼리 결과를 정렬하려면 다음을 사용해야합니다. ORDER BY절. 결과 집합의 개체에 대한 속성별로 오름차순 (ASC) 또는 내림차순 (DESC)으로 결과를 정렬 할 수 있습니다. 다음은 ORDER BY 절을 사용하는 간단한 구문입니다-
String hql = "FROM Employee E WHERE E.id > 10 ORDER BY E.salary DESC";
Query query = session.createQuery(hql);
List results = query.list();
둘 이상의 속성을 기준으로 정렬하려면 다음과 같이 쉼표로 구분하여 order by 절 끝에 추가 속성을 추가하면됩니다.
String hql = "FROM Employee E WHERE E.id > 10 " +
"ORDER BY E.firstName DESC, E.salary DESC ";
Query query = session.createQuery(hql);
List results = query.list();
GROUP BY 절
이 절은 Hibernate가 데이터베이스에서 정보를 가져와 속성 값을 기반으로 그룹화하고 일반적으로 결과를 사용하여 집계 값을 포함하도록합니다. 다음은 GROUP BY 절을 사용하는 간단한 구문입니다-
String hql = "SELECT SUM(E.salary), E.firtName FROM Employee E " +
"GROUP BY E.firstName";
Query query = session.createQuery(hql);
List results = query.list();
명명 된 매개 변수 사용
Hibernate는 HQL 쿼리에서 명명 된 매개 변수를 지원합니다. 이를 통해 사용자의 입력을 받아들이는 HQL 쿼리를 쉽게 작성할 수 있으며 SQL 주입 공격을 방어 할 필요가 없습니다. 다음은 명명 된 매개 변수를 사용하는 간단한 구문입니다.
String hql = "FROM Employee E WHERE E.id = :employee_id";
Query query = session.createQuery(hql);
query.setParameter("employee_id",10);
List results = query.list();
UPDATE 절
대량 업데이트는 Hibernate 3에서 HQL에 새로 추가되었으며 Hibernate 2 에서와는 다르게 Hibernate 3에서 작업을 삭제합니다. Query 인터페이스는 이제 HQL UPDATE 또는 DELETE 문을 실행하기위한 executeUpdate ()라는 메서드를 포함합니다.
그만큼 UPDATE절은 하나 이상의 객체에 대한 하나 이상의 속성을 업데이트하는 데 사용할 수 있습니다. 다음은 UPDATE 절을 사용하는 간단한 구문입니다-
String hql = "UPDATE Employee set salary = :salary " +
"WHERE id = :employee_id";
Query query = session.createQuery(hql);
query.setParameter("salary", 1000);
query.setParameter("employee_id", 10);
int result = query.executeUpdate();
System.out.println("Rows affected: " + result);
DELETE 절
그만큼 DELETE절을 사용하여 하나 이상의 개체를 삭제할 수 있습니다. 다음은 DELETE 절을 사용하는 간단한 구문입니다-
String hql = "DELETE FROM Employee " +
"WHERE id = :employee_id";
Query query = session.createQuery(hql);
query.setParameter("employee_id", 10);
int result = query.executeUpdate();
System.out.println("Rows affected: " + result);
INSERT 절
HQL 지원 INSERT INTO한 개체에서 다른 개체로 레코드를 삽입 할 수있는 경우에만 절입니다. 다음은 INSERT INTO 절을 사용하는 간단한 구문입니다.
String hql = "INSERT INTO Employee(firstName, lastName, salary)" +
"SELECT firstName, lastName, salary FROM old_employee";
Query query = session.createQuery(hql);
int result = query.executeUpdate();
System.out.println("Rows affected: " + result);
집계 방법
HQL은 SQL과 유사한 다양한 집계 메서드를 지원합니다. 그들은 HQL에서 SQL과 같은 방식으로 작동하며 다음은 사용 가능한 함수 목록입니다.
Sr. 아니. | 기능 및 설명 |
---|---|
1 |
avg(property name) 부동산 가치의 평균 |
2 |
count(property name or *) 결과에서 속성이 발생하는 횟수 |
삼 |
max(property name) 속성 값의 최대 값 |
4 |
min(property name) 속성 값의 최소값 |
5 |
sum(property name) 속성 값의 합계 |
그만큼 distinct키워드는 행 집합의 고유 값만 계산합니다. 다음 쿼리는 고유 개수 만 반환합니다-
String hql = "SELECT count(distinct E.firstName) FROM Employee E";
Query query = session.createQuery(hql);
List results = query.list();
쿼리를 사용한 페이지 매김
페이지 매김을위한 Query 인터페이스에는 두 가지 방법이 있습니다.
Sr. 아니. | 방법 및 설명 |
---|---|
1 |
Query setFirstResult(int startPosition) 이 메서드는 결과 집합의 첫 번째 행을 나타내는 정수를 취하며 행 0부터 시작합니다. |
2 |
Query setMaxResults(int maxResult) 이 메소드는 Hibernate에게 고정 된 숫자를 검색하도록 지시합니다. maxResults 개체의. |
위의 두 가지 방법을 함께 사용하면 웹 또는 스윙 애플리케이션에서 페이징 구성 요소를 구성 할 수 있습니다. 다음은 한 번에 10 개의 행을 가져 오도록 확장 할 수있는 예입니다.
String hql = "FROM Employee";
Query query = session.createQuery(hql);
query.setFirstResult(1);
query.setMaxResults(10);
List results = query.list();