教你快速學(xué)會JPA中所有findBy語法規(guī)則
快速學(xué)會JPA中所有findBy語法規(guī)則
1、findBy findAllBy的區(qū)別
它們之間沒有區(qū)別,它們將執(zhí)行完全相同的查詢,當(dāng)從方法名稱派生查詢時,Spring Data會忽略All部分。唯一重要的一點是By關(guān)鍵字,其后面的任何內(nèi)容都被視為字段名稱
如 findXXXXXXXXXXXXXByName 實際上==》 findByName
2、JPA中支持的關(guān)鍵詞
And
:等價于 SQL 中的 and 關(guān)鍵字,比如 findByUsernameAndPassword(String user, Striang pwd);
Or
:等價于 SQL 中的 or 關(guān)鍵字,比如 findByUsernameOrAddress(String user, String addr);
Between
:等價于 SQL 中的 between 關(guān)鍵字,比如 findBySalaryBetween(int max, int min);
LessThan
:等價于 SQL 中的 "<",比如 findBySalaryLessThan(int max);
GreaterThan
:等價于 SQL 中的">",比如 findBySalaryGreaterThan(int min);
IsNull
:等價于 SQL 中的 "is null",比如 findByUsernameIsNull();
IsNotNull
:等價于 SQL 中的 "is not null",比如 findByUsernameIsNotNull();
NotNull
:與 IsNotNull 等價;
Like
:等價于 SQL 中的 "like",比如 findByUsernameLike(String user);但是有一點需要注意的是,%需要我們自己來寫
NotLike
:等價于 SQL 中的 "not like",比如 findByUsernameNotLike(String user);
OrderBy
:等價于 SQL 中的 "order by",比如 findByUsernameOrderBySalaryAsc(String user);
Not
:等價于 SQL 中的 "! =",比如 findByUsernameNot(String user);
In
:等價于 SQL 中的 "in",比如 findByUsernameIn(Collection<String> userList) ,方法的參數(shù)可以是 Collection 類型,也可以是數(shù)組或者不定長參數(shù);
NotIn
:等價于 SQL 中的 "not in",比如 findByUsernameNotIn(Collection<String> userList) ,方法的參數(shù)可以是 Collection 類型,也可以是數(shù)組或者不定長參數(shù);
JPA findBy 語法總結(jié)
1、JPA同時查詢兩個屬性
其中一個是embedded class的屬性
findByIdageAndTime(int age, Date time)
2、表格匯總
3、Spring Data JPA框架在進行方法名解析時
會先把方法名多余的前綴截取掉,比如 find、findBy、read、readBy、get、getBy,然后對剩下部分進行解析。
4、JPA的NamedQueries
在實體類上使用@NamedQuery,示例如下:
@NamedQuery(name = "UserModel.findByAge",query = "select o from UserModel o where o.age >= ?1")
在自己實現(xiàn)的DAO的Repository接口里面定義一個同名的方法,示例如下:
public List findByAge(int age);
然后就可以使用了,Spring會先找是否有同名的NamedQuery,如果有,那么就不會按照接口定義的方法來解析。
5、JPQL查詢
@Query("from SysUser u where u.nickname=:nickname") SysUser findUser(@Param("nickname") String nickname); @Query("from SysUser u where u.nickname like %:nickname% order by u.fans desc") List<SysUser> findUsers(@Param("nickname") String nickname);
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
使用Spring AntPathMatcher的doMatch方法
這篇文章主要介紹了使用Spring AntPathMatcher的doMatch方法,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-09-09詳解使用spring cloud config來統(tǒng)一管理配置文件
這篇文章主要介紹了詳解使用spring cloud config來統(tǒng)一管理配置文件,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-12-12spring boot starter actuator(健康監(jiān)控)配置和使用教程
這篇文章主要介紹了spring-boot-starter-actuator(健康監(jiān)控)配置和使用教程,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下2018-06-06