一、相关接口方法

    在继承JpaRepository接口后,自动拥有了按“实例”进行查询的诸多方法。这些方法主要在两个接口中定义,一是QueryByExampleExecutor,一个是JpaRepository,如下所示:
public interface QueryByExampleExecutor<T> {
<S extends T> S findOne(Example<S> example); //根据“实例”查找一个对象。
<S extends T> Iterable<S> findAll(Example<S> example); //根据“实例”查找一批对象
<S extends T> Iterable<S> findAll(Example<S> example, Sort sort); //根据“实例”查找一批对象,且排序
<S extends T> Page<S> findAll(Example<S> example, Pageable pageable); //根据“实例”查找一批对象,且排序和分页
<S extends T> long count(Example<S> example); //根据“实例”查找,返回符合条件的对象个数
<S extends T> boolean exists(Example<S> example); //根据“实例”判断是否有符合条件的对象
}
@NoRepositoryBean public interface JpaRepository<T, ID extends Serializable>
  extends PagingAndSortingRepository<T, ID>, QueryByExampleExecutor<T> {
......
@Override
<S extends T> List<S> findAll(Example<S> example); //根据实例查询
@Override
<S extends T> List<S> findAll(Example<S> example, Sort sort);//根据实例查询,并排序。
}

返回单一对象精准匹配:
ProductCategory productCategory = new ProductCategory();

productCategory.setCategoryId(111);
//将匹配对象封装成Example对象
Example<ProductCategory> example =Example.of(productCategory);
//根据id:111精准匹配对象,id必须是唯一主键,查出2条会报错
Optional<ProductCategory> one = repository.findOne(example);
多条件,返回集合:

ProductCategory productCategory = new ProductCategory();
productCategory.setCategoryName("喜欢");
 //创建匹配器,即如何使用查询条件
ExampleMatcher exampleMatcher = ExampleMatcher.matching().withMatcher("categoryName",,ExampleMatcher.GenericPropertyMatchers.endsWith())//endsWith是categoryName 结尾为喜欢的数据
        .withMatcher("categoryName",ExampleMatcher.GenericPropertyMatchers.startsWith())   //
.withIgnorePaths("isFace");//isFace字段不参与匹配
//创建实例
Example<ProductCategory> example =Example.of(productCategory,exampleMatcher); //查询
List<ProductCategory> one = repository.findAll(example);
System.out.println(one);

最新文章

  1. PHP 做文件校验,MD5,CRC32,SHA等
  2. JAVA实现发送电子邮件
  3. 【BZOJ-2668】交换棋子 最小费用最大流
  4. ajax下载多文件,并且打包 C#中 ,文件批下载zip
  5. matlab参数查询
  6. js实现touch移动触屏滑动事件
  7. CentOS 7 ibus 导入第三方词库
  8. ENVI/IDL与ArcGIS集成开发的三种途径
  9. iframe和response.sendRedirect使用的问题
  10. Servlet -- 跳转到页面后的绝对路径与相对路径的问题
  11. Android学习笔记(九)——更复杂的进度对话框
  12. HTML5 实现拖拽
  13. 是否编码输出html字符
  14. python 字符串编码解码和格式化问题
  15. 转:[大数据竞赛]协同过滤在这个问题上是否work
  16. 2018.07.17 CQOI2017 余数求和(整除分块)
  17. 【WPF】TabControl禁用部分选项卡
  18. HTML5视频播放练习:鼠标经过视频播放,鼠标移除停止播放,再次经过继续播放。
  19. IP判断 (字符串处理)
  20. thymleaf th:text 和 th:utext 之间的区别

热门文章

  1. 老男孩九期全栈Python之基础一
  2. mysql:mysql is neither service nor target!?(suse12 sp2 )
  3. easyui 面板title 加东西
  4. java按照指定格式输出系统时间使用SimpleDateFormat方法
  5. java按照指定格式输出系统时间
  6. Linux命令练习
  7. Python2.X和Python3.X中Tkinter模块的文件对话框、下拉列表的不同
  8. Vue的自定义组件之间的数据传递
  9. Html骨架、基本语法
  10. 阶段02JavaWeb基础day01html&amp;css