激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達(dá)式|C/C++|IOS|C#|Swift|Android|VB|R語(yǔ)言|JavaScript|易語(yǔ)言|vb.net|

服務(wù)器之家 - 編程語(yǔ)言 - Java教程 - Spring Data JPA 簡(jiǎn)單查詢--方法定義規(guī)則(詳解)

Spring Data JPA 簡(jiǎn)單查詢--方法定義規(guī)則(詳解)

2020-09-10 14:12Java之家 Java教程

下面小編就為大家?guī)?lái)一篇Spring Data JPA 簡(jiǎn)單查詢--方法定義規(guī)則(詳解)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧

一、常用規(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 JPA 簡(jiǎn)單查詢--方法定義規(guī)則(詳解)

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

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)行排序或者分頁(yè)查詢。

2、舉例說(shuō)明

比如 findByUserAddressZip()。框架在解析該方法時(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ù)從右往左截取;最后假設(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)烈建議:無(wú)論是否存在混淆,都要在不同類層級(jí)之間加上"_" ,增加代碼可讀性)

三、一些情況

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

舉例說(shuō)明如下:

實(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的記錄才符合條件,并不是說(shuō)忽略這個(gè)條件。也就是說(shuō),這種查詢方式,只適合于明確查詢條件必須傳的業(yè)務(wù),對(duì)于動(dòng)態(tài)查詢(條件多少是動(dòng)態(tài)的,例如一般的查詢列表,由最終用戶使用時(shí)決定輸入那些查詢條件),這種簡(jiǎn)單查詢是不能滿足要求的。

2、排序

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

以上這篇Spring Data JPA 簡(jiǎn)單查詢--方法定義規(guī)則(詳解)就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持服務(wù)器之家。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 国产精品美女一区二区 | 国产精品99久久久久久久vr | 羞羞的视频在线观看 | 日本a级一区 | 蜜桃视频日韩 | 国产精品wwww | 亚洲成人播放 | 日韩av在线资源 | 一级毛片在线视频 | 成人福利视频网站 | 久草在线视频看看 | 精品视频 久久久 | 色av网址 | 国产成人精品免费视频大全最热 | 久久精品99久久久久久2456 | 高清国产免费 | 国产免费人做人爱午夜视频 | 国内精品久久久久久久久久久久 | av电影在线免费 | 一区二区国产在线 | 国产精品a一 | 欧美一级理论 | 久久精品视频16 | 久久艹逼| 精品一区二区三区中文字幕老牛 | 国产成人精品一区二区视频免费 | 欧美一区二区三区四区五区动图 | 精品亚洲一区二区三区 | 欧美日韩亚洲国产精品 | 久久久成人精品视频 | 欧美性受xxxxxx黑人xyx性爽 | 亚洲男人的天堂在线视频 | 免费久久精品 | 成人激情久久 | 91国在线高清视频 | 九九热在线视频观看这里只有精品 | 日韩在线播放中文字幕 | 嗯哈~不行好大h双性 | 欧美a v在线 | 午夜小电影 | 成人免费一区二区三区在线观看 |