SpringData 方法定义规范

简单条件查询
简单条件查询 : 查询 某一个实体类或者集合 
按照 Spring D ata 的规范 查询方法 find | read | get 开头,  
涉及条件查询时,条件的属性用条件关键字连接,要注意的是:条件属性以首字母 大写  
例如 :定义一 Entity 实体 类 
classUser { 
  private String firstName
  private String lastName
} 
使用 And 条件连接时,应这样写: 
findByLastNameAndFirstName (String lastName,String firstName ); 
条件的属性名称与个数要与参数的位置与个数一一对应 

支持的关键字
直接在接口中定义查询方法,如果是符合规范的,可以不用写实现,目前支持的关键字写法如下:


查询方法解析流程

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值