CriteriaBuilder詳解

一、CriteriaBuilder介紹

CriteriaBuilder是JPA(Java Persistence API)2.0的一部分,用於動態構建類型安全的查詢語句。與靜態查詢語句相比,CriteriaBuilder的好處在於可以根據實際需要構建查詢語句,而不是在編寫代碼時就定義好所有查詢細節。

CriteriaBuilder可以幫助我們動態構建選擇、過濾、排序等查詢條件。它的作用是將查詢條件表示為一個對象,而不是一個字符串,因此可以在編譯時檢查語法錯誤和類型錯誤,避免運行時的錯誤。

CriteriaBuilder cb = em.getCriteriaBuilder();
CriteriaQuery<T> cq = cb.createQuery(T.class);
Root<T> root = cq.from(T.class);

二、選擇(SELECT)查詢

在CriteriaBuilder中,選擇(SELECT)查詢使用Selection對象表示。Selection對象代表查詢結果中的單個屬性。可以使用以下方法構建Selection對象:

  • CriteriaBuilder.tuple(Selection…)
  • Root.get(String)
  • Path.get(String)
  • CriteriaBuilder.construct(Class, Selection…)

下面是一個例子,查詢Person實體的firstName和lastName屬性:

CriteriaBuilder cb = em.getCriteriaBuilder();
CriteriaQuery<Object[]> cq = cb.createQuery(Object[].class);
Root<Person> root = cq.from(Person.class);
Selection<Object>[] selections = new Selection[] {
    root.get(Person_.firstName),
    root.get(Person_.lastName)
};
cq.select(cb.array(selections));

三、過濾(WHERE)查詢

在CriteriaBuilder中,過濾(WHERE)查詢使用Predicate對象表示。Predicate對象代表WHERE子句中的單個條件。可以使用以下方法構建Predicate對象:

  • Predicate alwaysTrue = cb.isTrue(cb.literal(true));
  • Predicate alwaysFalse = cb.isFalse(cb.literal(false));
  • Predicate isNull = cb.isNull(expression);
  • Predicate isNotNull = cb.isNotNull(expression);
  • Predicate like = cb.like(expression, pattern);
  • Predicate notLike = cb.notLike(expression, pattern);
  • Predicate equal = cb.equal(expression1, expression2);
  • Predicate notEqual = cb.notEqual(expression1, expression2);
  • Predicate greaterThan = cb.greaterThan(expression1, expression2);
  • Predicate greaterThanOrEqualTo = cb.greaterThanOrEqualTo(expression1, expression2);
  • Predicate lessThan = cb.lessThan(expression1, expression2);
  • Predicate lessThanOrEqualTo = cb.lessThanOrEqualTo(expression1, expression2);
  • Predicate and = cb.and(predicate1, predicate2);
  • Predicate or = cb.or(predicate1, predicate2);
  • Predicate not = cb.not(predicate);

下面是一個例子,過濾出age大於等於18歲並且firstName為“John”的Person實體:

CriteriaBuilder cb = em.getCriteriaBuilder();
CriteriaQuery<T> cq = cb.createQuery(T.class);
Root<Person> root = cq.from(Person.class);
Predicate agePredicate = cb.greaterThanOrEqualTo(root.get(Person_.age), 18);
Predicate firstNamePredicate = cb.equal(root.get(Person_.firstName), "John");
cq.where(cb.and(agePredicate, firstNamePredicate));

四、排序(ORDER BY)查詢

在CriteriaBuilder中,排序(ORDER BY)查詢使用Order對象表示。Order對象代表查詢結果中的單個屬性的排序方向。可以使用以下方法構建Order對象:

  • Order asc = cb.asc(expression);
  • Order desc = cb.desc(expression);

下面是一個例子,查詢Person實體並根據lastName屬性升序排序:

CriteriaBuilder cb = em.getCriteriaBuilder();
CriteriaQuery<T> cq = cb.createQuery(T.class);
Root<Person> root = cq.from(Person.class);
cq.orderBy(cb.asc(root.get(Person_.lastName)));

五、分組(GROUP BY)查詢

在CriteriaBuilder中,分組(GROUP BY)查詢使用Group對象表示。Group對象代表查詢結果中的單個屬性的分組條件。可以使用以下方法構建Group對象:

  • Group group = cb.groupBy(expression);

下面是一個例子,查詢Person實體並根據firstName屬性進行分組:

CriteriaBuilder cb = em.getCriteriaBuilder();
CriteriaQuery<Object[]> cq = cb.createQuery(Object[].class);
Root<Person> root = cq.from(Person.class);
cq.multiselect(root.get(Person_.firstName), cb.count(root));
cq.groupBy(root.get(Person_.firstName));

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/285634.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-12-22 15:45
下一篇 2024-12-22 15:45

相關推薦

  • Linux sync詳解

    一、sync概述 sync是Linux中一個非常重要的命令,它可以將文件系統緩存中的內容,強制寫入磁盤中。在執行sync之前,所有的文件系統更新將不會立即寫入磁盤,而是先緩存在內存…

    編程 2025-04-25
  • 神經網絡代碼詳解

    神經網絡作為一種人工智能技術,被廣泛應用於語音識別、圖像識別、自然語言處理等領域。而神經網絡的模型編寫,離不開代碼。本文將從多個方面詳細闡述神經網絡模型編寫的代碼技術。 一、神經網…

    編程 2025-04-25
  • nginx與apache應用開發詳解

    一、概述 nginx和apache都是常見的web服務器。nginx是一個高性能的反向代理web服務器,將負載均衡和緩存集成在了一起,可以動靜分離。apache是一個可擴展的web…

    編程 2025-04-25
  • Java BigDecimal 精度詳解

    一、基礎概念 Java BigDecimal 是一個用於高精度計算的類。普通的 double 或 float 類型只能精確表示有限的數字,而對於需要高精度計算的場景,BigDeci…

    編程 2025-04-25
  • 詳解eclipse設置

    一、安裝與基礎設置 1、下載eclipse並進行安裝。 2、打開eclipse,選擇對應的工作空間路徑。 File -> Switch Workspace -> [選擇…

    編程 2025-04-25
  • git config user.name的詳解

    一、為什麼要使用git config user.name? git是一個非常流行的分布式版本控制系統,很多程序員都會用到它。在使用git commit提交代碼時,需要記錄commi…

    編程 2025-04-25
  • Python輸入輸出詳解

    一、文件讀寫 Python中文件的讀寫操作是必不可少的基本技能之一。讀寫文件分別使用open()函數中的’r’和’w’參數,讀取文件…

    編程 2025-04-25
  • MPU6050工作原理詳解

    一、什麼是MPU6050 MPU6050是一種六軸慣性傳感器,能夠同時測量加速度和角速度。它由三個傳感器組成:一個三軸加速度計和一個三軸陀螺儀。這個組合提供了非常精細的姿態解算,其…

    編程 2025-04-25
  • Linux修改文件名命令詳解

    在Linux系統中,修改文件名是一個很常見的操作。Linux提供了多種方式來修改文件名,這篇文章將介紹Linux修改文件名的詳細操作。 一、mv命令 mv命令是Linux下的常用命…

    編程 2025-04-25
  • Python安裝OS庫詳解

    一、OS簡介 OS庫是Python標準庫的一部分,它提供了跨平台的操作系統功能,使得Python可以進行文件操作、進程管理、環境變量讀取等系統級操作。 OS庫中包含了大量的文件和目…

    編程 2025-04-25

發表回復

登錄後才能評論