JPQL
查询语言
JPQL全称Java Persistence Query Language。
内容简介
JPQL所提供的查询语法主要分为三类:
SELECT 语法结构由几个部份组成:
SELECT 子句 FROM 子句 [WHERE 子句] [GROUP BY 子句] [HAVING 子句] [ORDER BY 子句]
一个基本的 SELECT 语句如下所示:
SELECT u.id, u.name FROM User u WHERE u.age > 10 AND u.age < 20
其中User u是个路径表示(path expression),路径表示有三种:范围变数(Range variable)路径表示、群集成员(Collection member)路径表示与关联导览(Association traversing)表示。User u是范围变数路径表示的一个例子,指定查询的实体为User与别名为u。
一个群集成员路径表示用来指定物件中的群集成员,例如:
SELECT u FROM User u, IN(u.emails) e WHERE e.address LIKE '%.%@openhome.cc'
其中IN中指定的,就是群集成员路径表示,而>、<、AND、IN、LIKE等都是WHERE子句中条件表示式,简单列出一些条件表示式如下:
LIKE中,可以用_表示比对单一字元,用%表示比对任意数目字元。
关联导览表示则提供SQL语法中JOIN的功能,包括了INNER JOIN、LEFT OUTER JOIN、FETCH等,以下为INNER JOIN的实际例子:
SELECT u FROM User u INNER JOINu.emails e WHERE e.address LIKE '%.%@openhome.cc'
JOIN关键字可以省略,上式等同於:
SELECT u FROM User u JOINu.emails e WHERE e.address LIKE '%.%@openhome.cc'
LEFT OUTER JOIN的OUTER关键字可以省略,一个例子如下:
SELECT u FROM User u LEFT JOIN u.emails e WHERE e.address LIKE'%.%@openhome.cc'
在作INNER JOIN、LEFT OUTER JOIN可以加上FETCH关键字,以预先撷取相关资料,例如:
SELECT u FROM User u LEFT JOIN FETCH u.emails e WHERE e.address LIKE'%.%@openhome.cc'
SELECT中可以使用聚集函式,例如:
SELECT AVG(u.age) FROM User u
SELECT中可以使用建构表示,直接将一些资料封装为指定的物件,例如:
SELECT NEW SomeObject(u.id, u.name, o.number) FROM User u JOIN Order o WHERE u.id = 1975
WHERE子句中可以使用LENGTH()、LOWER()、UPPER()、SUBSTRING()等JPQL函式。
可以对查询结果使用ORDER BY进行排序:
SELECT u FROM User u ORDER BY u.age
ORDER预设是ASC昇幂排序,可使用DESC降幂排序:
SELECT u FROM User u ORDER BY u.age DESC
SELECT u FROM User u ORDER BY u.age DESC, u.name
SELECT u.sex, AVG(u.age) FROM User u GROUP BY u.sex
GROUP BY通常搭配HAVING来使用,例如:
SELECT u.sex, avg(u.age) FROM User u GROUP BY u.sex HAVING AVG(u.age) > 20
可以使用UPDATE语法来更新资料,例如:
UPDATE User u SET u.name='momor' WHERE u.name='bbb'
可以透过DELETE来删除资料,例如:
DELETE User u WHERE u.name='bush'
查询方式
选择查询
SELECT <select_expression>
FROM <from_clause>
[WHERE <conditional_expression>]
[ORDER BY <order_by_clause>]
聚合查询
SELECT <select_expression
FROM <from_clause>
[WHERE <conditional_expression>]
[GROUP BY <group_by_clause>]
[HAVING <conditional_expression>]
[ORDER BY <order_by_clause>]
更新查询
UPDATE <entity name>[ [AS ] <identification variable>]
SET <update_statement>{,<update_statement>}*
[WHERE <conditional_expression>]
删除查询
DELETE FROM <entity name>[ [AS ] <identification variable>]
[WHERE <conditional_expression>]
参考资料
最新修订时间:2024-06-27 21:06
目录
概述
内容简介
参考资料