欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

使用SpringDataJPA如何實(shí)現(xiàn)自定義規(guī)則查詢(xún)-創(chuàng)新互聯(lián)

創(chuàng)新互聯(lián)www.cdcxhl.cn八線(xiàn)動(dòng)態(tài)BGP香港云服務(wù)器提供商,新人活動(dòng)買(mǎi)多久送多久,劃算不套路!

讓客戶(hù)滿(mǎn)意是我們工作的目標(biāo),不斷超越客戶(hù)的期望值來(lái)自于我們對(duì)這個(gè)行業(yè)的熱愛(ài)。我們立志把好的技術(shù)通過(guò)有效、簡(jiǎn)單的方式提供給客戶(hù),將通過(guò)不懈努力成為客戶(hù)在信息化領(lǐng)域值得信任、有價(jià)值的長(zhǎng)期合作伙伴,公司提供的服務(wù)項(xiàng)目有:空間域名、網(wǎng)頁(yè)空間、營(yíng)銷(xiāo)軟件、網(wǎng)站建設(shè)、黃浦網(wǎng)站維護(hù)、網(wǎng)站推廣。

使用Spring Data JPA如何實(shí)現(xiàn)自定義規(guī)則查詢(xún)?針對(duì)這個(gè)問(wèn)題,這篇文章詳細(xì)介紹了相對(duì)應(yīng)的分析和解答,希望可以幫助更多想解決這個(gè)問(wèn)題的小伙伴找到更簡(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    模糊查詢(xún)。查詢(xún)件中需要自己加 %
14  NotLike     不在模糊范圍內(nèi)。查詢(xún)件中需要自己加 %
15  StartingWith  以某開(kāi)頭
16  EndingWith    以某結(jié)束
17  Containing   包含某
18  OrderBy  排序
19  Not    不等于
20  In     某范圍內(nèi)
21  NotIn    某范圍外
22  True    真
23  False    假
24  IgnoreCase  忽略大小寫(xiě)

使用Spring Data JPA如何實(shí)現(xiàn)自定義規(guī)則查詢(xún)

二、Spring Data 解析方法名--規(guī)則說(shuō)明

1、規(guī)則描述

按照Spring data 定義的規(guī)則,查詢(xún)方法以find|read|get開(kāi)頭(比如 find、findBy、read、readBy、get、getBy),涉及條件查詢(xún)時(shí),條件的屬性用條件關(guān)鍵字連接,要注意的是:條件屬性首字母需大寫(xiě)??蚣茉谶M(jìn)行方法名解析時(shí),會(huì)先把方法名多余的前綴截取掉,然后對(duì)剩下部分進(jìn)行解析。

如果方法的最后一個(gè)參數(shù)是 Sort 或者 Pageable 類(lèi)型,也會(huì)提取相關(guān)的信息,以便按規(guī)則進(jìn)行排序或者分頁(yè)查詢(xún)。

2、舉例說(shuō)明

比如 findByUserAddressZip()??蚣茉诮馕鲈摲椒〞r(shí),首先剔除 findBy,然后對(duì)剩下的屬性進(jìn)行解析,詳細(xì)規(guī)則如下(此處假設(shè)該方法針對(duì)的域?qū)ο鬄?AccountInfo 類(lèi)型):

先判斷 userAddressZip (根據(jù) POJO 規(guī)范,首字母變?yōu)樾?xiě),下同)是否為 AccountInfo 的一個(gè)屬性,如果是,則表示根據(jù)該屬性進(jìn)行查詢(xún);如果沒(méi)有該屬性,繼續(xù)第二步;

從右往左截取第一個(gè)大寫(xiě)字母開(kāi)頭的字符串(此處為 Zip),然后檢查剩下的字符串是否為 AccountInfo 的一個(gè)屬性,如果是,則表示根據(jù)該屬性進(jìn)行查詢(xún);如果沒(méi)有該屬性,則重復(fù)第二步,繼續(xù)從右往左截??;最后假設(shè) user 為 AccountInfo 的一個(gè)屬性;

接著處理剩下部分( AddressZip ),先判斷 user 所對(duì)應(yīng)的類(lèi)型是否有 addressZip 屬性,如果有,則表示該方法最終是根據(jù) "AccountInfo.user.addressZip" 的取值進(jìn)行查詢(xún);否則繼續(xù)按照步驟 2 的規(guī)則從右往左截取,最終表示根據(jù) "AccountInfo.user.address.zip" 的值進(jìn)行查詢(xún)。

可能會(huì)存在一種特殊情況,比如 AccountInfo 包含一個(gè) user 的屬性,也有一個(gè) userAddress 屬性,此時(shí)會(huì)存在混淆。讀者可以明確在屬性之間加上 "_" 以顯式表達(dá)意圖,比如 "findByUser_AddressZip()" 或者 "findByUserAddress_Zip()"。(強(qiáng)烈建議:無(wú)論是否存在混淆,都要在不同類(lèi)層級(jí)之間加上"_" ,增加代碼可讀性)

三、一些情況

1、當(dāng)查詢(xún)條件為null時(shí)。

舉例說(shuō)明如下:

實(shí)體定義:對(duì)于一個(gè)客戶(hù)實(shí)體Cus,包含有name和sex,均是String類(lèi)型。

查詢(xún)方法定義:List<Cus> findByNameAndSex(String name,String sex);

使用時(shí):dao.findByNameAndSex(null, "男");

后臺(tái)生成sql片斷:where (cus0_.name is null) and cus0_.sex=&#63;

結(jié)論:當(dāng)查詢(xún)時(shí)傳值是null時(shí),數(shù)據(jù)庫(kù)中只有該字段是null的記錄才符合條件,并不是說(shuō)忽略這個(gè)條件。也就是說(shuō),這種查詢(xún)方式,只適合于明確查詢(xún)條件必須傳的業(yè)務(wù),對(duì)于動(dòng)態(tài)查詢(xún)(條件多少是動(dòng)態(tài)的,例如一般的查詢(xún)列表,由最終用戶(hù)使用時(shí)決定輸入那些查詢(xún)條件),這種簡(jiǎn)單查詢(xún)是不能滿(mǎn)足要求的。

2、排序

List<Cus> findBySexOrderByName(String sex); //名稱(chēng)正序(正序時(shí),推薦此方式,簡(jiǎn)單)
List<Cus> findBySexOrderByNameAsc(String sex); //名稱(chēng)正序(效果同上)
List<Cus> findBySexOrderByNameDesc(String sex); //名稱(chēng)倒序

當(dāng)前標(biāo)題:使用SpringDataJPA如何實(shí)現(xiàn)自定義規(guī)則查詢(xún)-創(chuàng)新互聯(lián)
文章轉(zhuǎn)載:http://chinadenli.net/article26/ddggcg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供小程序開(kāi)發(fā)、移動(dòng)網(wǎng)站建設(shè)、微信公眾號(hào)企業(yè)建站、ChatGPT、網(wǎng)站維護(hù)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話(huà):028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

外貿(mào)網(wǎng)站建設(shè)