您好,登錄后才能下訂單哦!
使用Spring Data JPA如何實(shí)現(xiàn)自定義規(guī)則查詢?針對(duì)這個(gè)問題,這篇文章詳細(xì)介紹了相對(duì)應(yīng)的分析和解答,希望可以幫助更多想解決這個(gè)問題的小伙伴找到更簡(jiǎn)單易行的方法。
一、常用規(guī)則速查
1 And 并且
2 Or 或
3 Is,Equals 等于
4 Between 兩者之間
5 LessThan 小于
6 LessThanEqual 小于等于
7 GreaterThan 大于
8 GreaterThanEqual 大于等于
9 After 之后(時(shí)間) >
10 Before 之前(時(shí)間) <
11 IsNull 等于Null
12 IsNotNull,NotNull 不等于Null
13 Like 模糊查詢。查詢件中需要自己加 %
14 NotLike 不在模糊范圍內(nèi)。查詢件中需要自己加 %
15 StartingWith 以某開頭
16 EndingWith 以某結(jié)束
17 Containing 包含某
18 OrderBy 排序
19 Not 不等于
20 In 某范圍內(nèi)
21 NotIn 某范圍外
22 True 真
23 False 假
24 IgnoreCase 忽略大小寫
二、Spring Data 解析方法名--規(guī)則說明
1、規(guī)則描述
按照Spring data 定義的規(guī)則,查詢方法以find|read|get開頭(比如 find、findBy、read、readBy、get、getBy),涉及條件查詢時(shí),條件的屬性用條件關(guān)鍵字連接,要注意的是:條件屬性首字母需大寫。框架在進(jìn)行方法名解析時(shí),會(huì)先把方法名多余的前綴截取掉,然后對(duì)剩下部分進(jìn)行解析。
如果方法的最后一個(gè)參數(shù)是 Sort 或者 Pageable 類型,也會(huì)提取相關(guān)的信息,以便按規(guī)則進(jìn)行排序或者分頁查詢。
2、舉例說明
比如 findByUserAddressZip()??蚣茉诮馕鲈摲椒〞r(shí),首先剔除 findBy,然后對(duì)剩下的屬性進(jìn)行解析,詳細(xì)規(guī)則如下(此處假設(shè)該方法針對(duì)的域?qū)ο鬄?AccountInfo 類型):
先判斷 userAddressZip (根據(jù) POJO 規(guī)范,首字母變?yōu)樾懀峦┦欠駷?AccountInfo 的一個(gè)屬性,如果是,則表示根據(jù)該屬性進(jìn)行查詢;如果沒有該屬性,繼續(xù)第二步;
從右往左截取第一個(gè)大寫字母開頭的字符串(此處為 Zip),然后檢查剩下的字符串是否為 AccountInfo 的一個(gè)屬性,如果是,則表示根據(jù)該屬性進(jìn)行查詢;如果沒有該屬性,則重復(fù)第二步,繼續(xù)從右往左截?。蛔詈蠹僭O(shè) user 為 AccountInfo 的一個(gè)屬性;
接著處理剩下部分( AddressZip ),先判斷 user 所對(duì)應(yīng)的類型是否有 addressZip 屬性,如果有,則表示該方法最終是根據(jù) "AccountInfo.user.addressZip" 的取值進(jìn)行查詢;否則繼續(xù)按照步驟 2 的規(guī)則從右往左截取,最終表示根據(jù) "AccountInfo.user.address.zip" 的值進(jìn)行查詢。
可能會(huì)存在一種特殊情況,比如 AccountInfo 包含一個(gè) user 的屬性,也有一個(gè) userAddress 屬性,此時(shí)會(huì)存在混淆。讀者可以明確在屬性之間加上 "_" 以顯式表達(dá)意圖,比如 "findByUser_AddressZip()" 或者 "findByUserAddress_Zip()"。(強(qiáng)烈建議:無論是否存在混淆,都要在不同類層級(jí)之間加上"_" ,增加代碼可讀性)
三、一些情況
1、當(dāng)查詢條件為null時(shí)。
舉例說明如下:
實(shí)體定義:對(duì)于一個(gè)客戶實(shí)體Cus,包含有name和sex,均是String類型。
查詢方法定義:List<Cus> findByNameAndSex(String name,String sex);
使用時(shí):dao.findByNameAndSex(null, "男");
后臺(tái)生成sql片斷:where (cus0_.name is null) and cus0_.sex=?
結(jié)論:當(dāng)查詢時(shí)傳值是null時(shí),數(shù)據(jù)庫(kù)中只有該字段是null的記錄才符合條件,并不是說忽略這個(gè)條件。也就是說,這種查詢方式,只適合于明確查詢條件必須傳的業(yè)務(wù),對(duì)于動(dòng)態(tài)查詢(條件多少是動(dòng)態(tài)的,例如一般的查詢列表,由最終用戶使用時(shí)決定輸入那些查詢條件),這種簡(jiǎn)單查詢是不能滿足要求的。
2、排序
List<Cus> findBySexOrderByName(String sex); //名稱正序(正序時(shí),推薦此方式,簡(jiǎn)單) List<Cus> findBySexOrderByNameAsc(String sex); //名稱正序(效果同上) List<Cus> findBySexOrderByNameDesc(String sex); //名稱倒序
關(guān)于使用Spring Data JPA如何實(shí)現(xiàn)自定義規(guī)則查詢問題的解答就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關(guān)注億速云行業(yè)資訊頻道了解更多相關(guān)知識(shí)。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。