相关文章推荐
打酱油的野马  ·  oracle ...·  3 周前    · 
气势凌人的稀饭  ·  android - How to ...·  10 月前    · 
心软的火锅  ·  qgraphicsscene - ...·  1 年前    · 

JPA同时查询两个属性, 其中一个是embedded class的属性
findByIdageAndTime(int age, Date time)

深入浅出学Spring Data JPA (转)

JpaRepository的查询

findOne 根据主键id查询

findAll 查询所有

http://sishuok.com/forum/upload/2013/7/24/053ba2018612e06a66ce63ddadf1d4df__1.PNG

Spring Data JPA框架在进行方法名解析时,会先把方法名多余的前缀截取掉,比如 find、findBy、read、readBy、get、getBy,然后对剩下部分进行解析。
假如创建如下的查询:findByUserDepUuid(),框架在解析该方法时,首先剔除 findBy,然后对剩下的属性进行解析,假设查询实体为Doc
1:先判断 userDepUuid (根据 POJO 规范,首字母变为小写)是否为查询实体的一个属性,如果是,则表示根据该属性进行查询;如果没有该属性,继续第二步;
2:从右往左截取第一个大写字母开头的字符串此处为Uuid),然后检查剩下的字符串是否为查询实体的一个属性,如果是,则表示根据该属性进行查询;如果没有该属性,则重复第二步,继续从右往左截取;最后假设user为查询实体的一个属性;
3:接着处理剩下部分(DepUuid),先判断 user 所对应的类型是否有depUuid属性,如果有,则表示该方法最终是根据 “ Doc.user.depUuid” 的取值进行查询;否则继续按照步骤 2 的规则从右往左截取,最终表示根据 “Doc.user.dep.uuid” 的值进行查询。
4:可能会存在一种特殊情况,比如 Doc包含一个 user 的属性,也有一个 userDep 属性,此时会存在混淆。可以明确在属性之间加上 “_” 以显式表达意图,比如 “findByUser_DepUuid()” 或者 “findByUserDep_uuid()”
特殊的参数: 还可以直接在方法的参数上加入分页或排序的参数,比如:
Page findByName(String name, Pageable pageable);
List findByName(String name, Sort sort);

也可以使用JPA的NamedQueries,方法如下:
1:在实体类上使用@NamedQuery,示例如下:
@NamedQuery(name = “UserModel.findByAge”,query = “select o from UserModel o where o.age >= ?1”)
2:在自己实现的DAO的Repository接口里面定义一个同名的方法,示例如下:
public List findByAge(int age);
3:然后就可以使用了,Spring会先找是否有同名的NamedQuery,如果有,那么就不会按照接口定义的方法来解析。

JPA同时查询两个属性, 其中一个是embedded class的属性findByIdageAndTime(int age, Date time)深入浅出学Spring Data JPA (转)JpaRepository的查询findOne 根据主键id查询findAll 查询所有http://sishuok.com/forum/upload/2013/7/24/053ba2018612e06a66ce63ddadf1d4df__1.PNGSpring Data JPA框架在进行方法名解 Spring Data JPA 提供的一个 查询 规范, 查询 语句关键字,简单的SQL可根据方法命名来即可,省略了写sql语句。 关键字 方法命名 sql where字句 And findByNameAndPwd where name= ? and pwd =? Or fin
//该种命名方式需要自己写JPQL @Query("select d from Device d where d.deviceCode in ?1") List<Device> findAllByDeviceCode(List<String> deviceCodes); //方法命名规则 查询 ,如果入参想要是List,必须带 In List<Device> findAllByDeviceCodeIn(List<String&...
JPA 中支持的关键词: And --- 等价于 SQL 中的 and 关键字,比如 findByUsernameAndPassword(String user, Striang pwd); Or --- 等价于 SQL 中的 or 关键字,比如 findByUsernameOrAddress(String user, String addr); Between --- 等价于 SQL 中的 ...