GP Coder

Trang chia sẻ kiến thức lập trình Java

  • Java Core
    • Basic Java
    • OOP
    • Exception Handling
    • Multi-Thread
    • Java I/O
    • Networking
    • Reflection
    • Collection
    • Java 8
  • Design pattern
    • Creational Pattern
    • Structuaral Pattern
    • Behavior Pattern
  • Web Service
    • SOAP
    • REST
  • JPA
  • Java library
    • Report
    • Json
    • Unit Test
  • Message Queue
    • ActiveMQ
    • RabbitMQ
  • All
Trang chủ JPA Hibernate Criteria Query Language (HCQL)

Hibernate Criteria Query Language (HCQL)

Đăng vào 19/02/2020 . Được đăng bởi GP Coder . 12711 Lượt xem . Toàn màn hình

Trong bài trước, chúng ta đã cùng tìm hiểu về cách sử dụng Hibernate Query Language (HQL) để truy vấn cơ sở dữ liệu và nhận kết quả. Trong bài này, chúng ta sẽ cùng tìm hiểu về Hibernate Criteria Query Language – một cách khác để lấy dữ liệu dựa vào các tiêu chí (Criteria) cụ thể.

Nội dung

  • 1 Giới hiệu Hibernate Criteria Query Language (HCQL)
  • 2 Ví dụ sử dụng Hibernate Criteria Query Language (HCQL)
  • 3 Một số bất lợi khi sử dụng của Criteria

Giới hiệu Hibernate Criteria Query Language (HCQL)

Hibernate Criteria API cung cấp cách tiếp cận hướng đối tượng để truy vấn cơ sở dữ liệu và nhận kết quả. Criteria cho phép chúng ta xây dựng câu lệnh một cách linh động (dynamic) và không bị hardcode trong một chuỗi truy vấn và có thể tái sử dụng.

Một số trường hợp sử dụng phổ biến của Hibernate Criteria Query:

  • Sử dụng các hàm tập hợp như sum(), min(), max(), …
  • Truy vấn một vài column cụ thể.
  • Sử dụng để join nhiều table với nhau.
  • Giới hạn dữ liệu được trả về.
  • Sắp xếp (Order) kết quả trả về.
  • Phân trang (Paging).

Tương tự như HQL, để tạo đối tượng Criteria chúng ta sẽ sử dụng phương thức getCriteriaBuilder() từ đối tượng Session và tạo đối tượng Criteria: CriteriaQuery, createCriteriaUpdate, createCriteriaDelete.


<T> javax.persistence.criteria.CriteriaQuery<T> createQuery(java.lang.Class<T> aClass);

<T> javax.persistence.criteria.CriteriaUpdate<T> createCriteriaUpdate(java.lang.Class<T> aClass);

<T> javax.persistence.criteria.CriteriaDelete<T> createCriteriaDelete(java.lang.Class<T> aClass);

Ví dụ sử dụng Hibernate Criteria Query Language (HCQL)

Chúng ta sẽ sử dụng lại cơ sở dữ liệu ở bài viết trước để thực hiện các truy vấn với Criteria.

Lấy 1 đối tượng

Ví dụ lấy user có id là 1.


try (Session session = HibernateUtils.getSessionFactory().openSession();) {
    // Begin a unit of work
    session.beginTransaction();

    CriteriaBuilder builder = session.getCriteriaBuilder();

    CriteriaQuery<User> query = builder.createQuery(User.class);
    Root<User> root = query.from(User.class); // FROM User u
    query.select(root); // SELECT
    query.where(builder.equal(root.get("id"), 1)); // WHERE u.id = 1
    User user = session.createQuery(query).uniqueResult();

    // Commit the current resource transaction, writing any unflushed changes to the database.
    session.getTransaction().commit();
}

Lấy danh sách với paging và ordering

Ví dụ lấy danh sách user có id >= 1 và id <= 1000. Sắp xếp danh sách này theo ngày tạo giảm dần, tên tăng dần. Lấy từ 5 user bắt đầu từ vị trí thứ 10.


CriteriaBuilder builder = session.getCriteriaBuilder();
CriteriaQuery<User> query = builder.createQuery(User.class);
Root<User> root = query.from(User.class); // FROM
query.select(root); // SELECT
query.where(builder.and(builder.ge(root.get("id"), 1), builder.le(root.get("id"), 1000))); // WHERE id >= 1 AND id <= 1000
query.orderBy(builder.desc(root.get("createdAt")), builder.desc(root.asc("fullname"))); // ORDER BY createdAt DESC, fullname ASC
List<User> users = session.createQuery(query)
        .setFirstResult(10)
        .setMaxResults(5)
        .getResultList();

Lấy một column (Selecting an expression)

Ví dụ lấy tất cả email của user.


CriteriaBuilder builder = session.getCriteriaBuilder();
CriteriaQuery<String> query = builder.createQuery(String.class);
Root<User> root = query.from(User.class); // FROM
query.select(root.get("fullname")); // SELECT fullname
List<String> fullnames = session.createQuery(query).getResultList();

Lấy nhiều column (Selecting multiple values)


CriteriaBuilder builder = session.getCriteriaBuilder();
CriteriaQuery<Object[]> query = builder.createQuery(Object[].class);
Root<User> root = query.from(User.class); // FROM
query.multiselect(root.get("fullname"), root.get("username")); // SELECT fullname, username
List<Object[]> users = session.createQuery(query).getResultList();

Lấy nhiều column sử dụng Wrapper (Selecting a wrapper)

Thay vì trả về list Object[], chúng ta có thể trả về List POJO class như sau:

  • Tạo class mới, chứa các cột trả về.
  • Sử dụng phương thức construct của CriteriaBuilder để gán giá trị tương ứng cho wrapper class.

Chẳng hạn, cần lấy 2 column là fullname và username


@Data
@AllArgsConstructor
class BaseUser {
    private String fullname;
    private String username;
}


CriteriaBuilder builder = session.getCriteriaBuilder();
CriteriaQuery<BaseUser> query = builder.createQuery(BaseUser.class);
Root<User> root = query.from(User.class); // FROM
query.select( builder.construct( BaseUser.class, root.get("fullname"), root.get("username") ) ); // SELECT fullname, username
List<BaseUser> users = session.createQuery(query).getResultList();

Sử dụng hàm tập hợp (Aggregate Functions)

Ví dụ đếm số lượng user được tạo theo tháng.


CriteriaBuilder builder = session.getCriteriaBuilder();
CriteriaQuery<Object[]> query = builder.createQuery(Object[].class);
Root<User> root = query.from(User.class); 
Expression<Long> groupByExp = builder.function("month", Long.class, root.get("createdAt")).as(Long.class);
Expression<Long> countExp = builder.count(root.get("id"));
query.multiselect(groupByExp, countExp);
query.groupBy(groupByExp);
query.having(builder.gt(builder.count(root), 3));
//ordering by count in descending order
query.orderBy(builder.desc(countExp));

Truy vấn nhiều bảng (join)

Ví dụ: lấy thông tin user và user profile.


CriteriaBuilder builder = session.getCriteriaBuilder();
CriteriaQuery<User> query = builder.createQuery(User.class);
Root<User> root = query.from(User.class); // FROM
Join<User, UserProfile> userJoin = root.join("userProfile", JoinType.LEFT);
List<User> users = session.createQuery(query).getResultList();

Một số bất lợi khi sử dụng của Criteria

Như bạn thấy, Query với Criteria khá đơn giản. Tuy nhiên, nó có một số vấn đề sau chúng ta cần xem xét trước khi sử dụng:

  • Performance issue: Chúng ta không có cách nào để kiểm soát truy vấn SQL do Hibernate tạo ra, nếu truy vấn được tạo chậm, ta rất khó điều chỉnh truy vấn.
  • Maintenace issue: Tất cả các truy vấn SQL được phân tán thông qua mã code Java, khi một truy vấn bị lỗi, có thể dành thời gian để tìm truy vấn gây ra vấn đề trong ứng dụng của mình.

Không có gì là hoàn hảo, hãy xem xét nhu cầu dự án của mình và sử dụng nó một cách phù hợp. Đó cũng là một trong những lý dó mà Hibernate support nhiều loại truy vấn khác nhau.

Tài liệu tham khảo:

  • https://docs.jboss.org/hibernate/orm/5.4/userguide/html_single/Hibernate_User_Guide.html#criteria

 

4.9
11
Nếu bạn thấy hay thì hãy chia sẻ bài viết cho mọi người nhé! Và Donate tác giả

Shares

Chuyên mục: JPA Được gắn thẻ: Hibernate, JPA

Hibernate Query Language (HQL)
Hibernate Native SQL Queries

Có thể bạn muốn xem:

  • Tổng quan về JPA (Java Persistence API) (21/10/2019)
  • Hibernate reverse engineering – Customize code generation sử dụng custom strategy class (29/12/2019)
  • Tạo database table tự động từ Hibernate Entity (15/12/2019)
  • Hibernate mapping type (01/11/2019)
  • Giới thiệu về Hibernate (28/10/2019)

Bình luận

bình luận

Tìm kiếm

Bài viết mới

  • Clean code 13/01/2024
  • Giới thiệu CloudAMQP – Một RabbitMQ server trên Cloud 02/10/2020
  • Kết nối RabbitMQ sử dụng Web STOMP Plugin 19/06/2020
  • Sử dụng publisher confirm trong RabbitMQ 16/06/2020
  • Sử dụng Dead Letter Exchange trong RabbitMQ 13/06/2020

Xem nhiều

  • Hướng dẫn Java Design Pattern – Factory Method (98344 lượt xem)
  • Hướng dẫn Java Design Pattern – Singleton (97993 lượt xem)
  • Giới thiệu Design Patterns (88290 lượt xem)
  • Lập trình đa luồng trong Java (Java Multi-threading) (86793 lượt xem)
  • Giới thiệu về Stream API trong Java 8 (84149 lượt xem)

Nội dung bài viết

  • 1 Giới hiệu Hibernate Criteria Query Language (HCQL)
  • 2 Ví dụ sử dụng Hibernate Criteria Query Language (HCQL)
  • 3 Một số bất lợi khi sử dụng của Criteria

Lưu trữ

Thẻ đánh dấu

Annotation Authentication Basic Java Behavior Pattern Collection Creational Design Pattern Cấu trúc điều khiển Database Dependency Injection Design pattern Eclipse Exception Executor Service Google Guice Gson Hibernate How to Interceptor IO Jackson Java 8 Java Core JDBC JDK Jersey JMS JPA json JUnit JWT Message Queue Mockito Multithreading OOP PowerMockito RabbitMQ Reflection Report REST SOAP Structuaral Pattern Swagger Thread Pool Unit Test Webservice

Liên kết

  • Clean Code
  • JavaTpoint
  • Refactoring Guru
  • Source Making
  • TutorialsPoint
  • W3Schools Online Web Tutorials

Giới thiệu

GP Coder là trang web cá nhân, được thành lập với mục đích lưu trữ, chia sẽ kiến thức đã học và làm việc của tôi. Các bài viết trên trang này chủ yếu về ngôn ngữ Java và các công nghệ có liên quan đến Java như: Spring, JSF, Web Services, Unit Test, Hibernate, SQL, ...
Hi vọng góp được chút ít công sức cho sự phát triển cộng đồng Coder Việt.

Donate tác giả

Tìm kiếm các bài viết của GP Coder với Google Search

Liên hệ

Các bạn có thể liên hệ với tôi thông qua:
  • Trang liên hệ
  • Linkedin: gpcoder
  • Email: contact@gpcoder.com
  • Skype: ptgiang56it

Follow me

Copyright 2025 © GP Coder · All Rights Reserved · Giới thiệu · Chính sách · Điều khoản · Liên hệ ·

Share

Blogger
Delicious
Digg
Email
Facebook
Facebook messenger
Flipboard
Google
Hacker News
Line
LinkedIn
Mastodon
Mix
Odnoklassniki
PDF
Pinterest
Pocket
Print
Reddit
Renren
Short link
SMS
Skype
Telegram
Tumblr
Twitter
VKontakte
wechat
Weibo
WhatsApp
X
Xing
Yahoo! Mail

Copy short link

Copy link