技術(shù)員聯(lián)盟提供win764位系統(tǒng)下載,win10,win7,xp,裝機純凈版,64位旗艦版,綠色軟件,免費軟件下載基地!

當(dāng)前位置:主頁 > 教程 > 服務(wù)器類 >

Spring Data JPA 簡單查詢--方法定義規(guī)則

來源:技術(shù)員聯(lián)盟┆發(fā)布時間:2017-11-08 12:33┆點擊:

  一、常用規(guī)則速查

  1   And    并且

  2   Or     或

  3   Is,Equals    等于

  4   Between     兩者之間

  5   LessThan      小于

  6   LessThanEqual   小于等于

  7   GreaterThan     大于

  8   GreaterThanEqual  大于等于

  9   After    之后(時間) >

  10  Before    之前(時間) <

  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 簡單查詢--方法定義規(guī)則 三聯(lián)

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

  1、規(guī)則描述

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

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

  2、舉例說明

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

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

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

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

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

  三、一些情況

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

  舉例說明如下:

  實體定義:對于一個客戶實體Cus,包含有name和sex,均是String類型。

  查詢方法定義:List findByNameAndSex(String name,String sex);

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

  后臺生成sql片斷:where (cus0_.name is null) and cus0_.sex=?

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

  2、排序

  List findBySexOrderByName(String sex); //名稱正序(正序時,推薦此方式,簡單)

  List findBySexOrderByNameAsc(String sex); //名稱正序(效果同上)

  List findBySexOrderByNameDesc(String sex); //名稱倒序