最近一直在是用spring data jpa,使用起来确实方便,如果是单表的操作基本上通过方法名都可以实现,下面是一个

Specification 实现动态模糊查询的例子

这个查询是通过JpaSpecificationExecutor 这个接口实现的,只需要实现接口的toPredicate()方法jike,在Dao层不需要太多操作,只需生命接口,继承接口,声明方法即可
我这个实现是和分页排序接口在一块的,所以我是继承了两个接口,分页排序接口PagingAndSortingRepository,查询接口JpaSpecificationExecutor,这两个接口都是来自jpa的接口,在具体使用时
有这么一种情况,我不知道是不是普遍的或只是我的个例,就是如果只继承查询接口JpaSpecificationExecutor,会导致不能注入。下面贴代码:
1,dao层
public interface ParkInfoRepository extends PagingAndSortingRepository<ParkInfoPo, String> ,JpaSpecificationExecutor<ParkInfoPo> {
//查询所有
List<ParkInfoPo> findAll();
//模糊匹配搜索
List<ParkInfoPo> findAll(Specification<ParkInfoPo> specification);
}
dao层仅是声明接口,方法,继承,完成这些事情就可以了
2 service层实现
@Override
public ParkInfoPoList getParkInfoList(ParkInfoPo parkInfoPo) {
if(parkInfoPo!=null&&!StringUtils.isEmpty(parkInfoPo.getParkFullName())){
final String keyWords = parkInfoPo.getParkFullName();
List<ParkInfoPo> list = parkInfoRepository.findAll(new Specification<ParkInfoPo>() {
@Override
public Predicate toPredicate(Root<ParkInfoPo> root, CriteriaQuery<?> criteriaQuery, CriteriaBuilder cb) {
Predicate parkFullNamePredicate = cb.like(root.get("parkFullName").as(String.class), "%"+keyWords+"%");
criteriaQuery.where(cb.and(parkFullNamePredicate));
criteriaQuery.orderBy(cb.asc(root.get("updateTime").as(Date.class)));
return criteriaQuery.getRestriction();
}
});
return ParkInfoPoList.wrap(list);
}
List<ParkInfoPo> parkInfoPoList = parkInfoRepository.findAll();
return ParkInfoPoList.wrap(parkInfoPoList);
}
要把方法中的参数出入方法中的内部类,要用final类型,我这是只实现了一个查询条件即“parkFullName”,如果要用多个字段查询的话,可用拼接,如: query.where(cb.and(p3,cb.or(p1,p2)));
,还可以用list,如
  1. Specification<UserModel> spec = new Specification<UserModel>() {
  2. public Predicate toPredicate(Root<UserModel> root,
  3. CriteriaQuery<?> query, CriteriaBuilder cb) {
  4. List<Predicate> list = new ArrayList<Predicate>();
  5. if(um.getName()!=null && um.getName().trim().length()>0){
  6. list.add(cb.like(root.get("name").as(String.class), "%"+um.getName()+"%"));
  7. }
  8. if(um.getUuid()>0){
  9. list.add(cb.equal(root.get("uuid").as(Integer.class), um.getUuid()));
  10. }
  11. Predicate[] p = new Predicate[list.size()];
  12. return cb.and(list.toArray(p));
  13. }
  14. };  这段代码也是我从网上贴过来的,希望不要造成干扰
具体大家可以百度。我这只用了一个查询字段,还没扩充,这就是我得全部实现,其实也很简单。有什么不明白可以联系我,qq253364185,phone13524929851
 

												

一个jpa动态模糊查询的实现的更多相关文章

  1. input动态模糊查询的实现方式

    最近在用jQuery实现动态模糊查询的时候,找了挺久都没有找到像Vue.js的watch属性这么好用的动态模糊查询方法.就分享一下目前遇到的坑和可以实现动态查询的几种方式. 1.jQuery的chan ...

  2. 关于JPA动态SQL查询

    1.继承接口 2.下面是简单的操作---自己写过的,下次再整理一下 public Page<IdddsMember> list(MemberSearch search, Pageable ...

  3. MyBatis做动态模糊查询时,like后面要不要加单引号??

    做项目遇到了个奇怪的问题,项目里面要对商品.账户.进行分别的多条件查询,于是我就采用动态多条件分页查询,起初在做账户部分的时候Mybatis是这样写的 <!-- 动态多条件分页查询 --> ...

  4. input框动态模糊查询,能输入,能选择

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  5. SQLSERVER使用Spring Data JPA实现模糊查询like

    mysql下可以使用 CONCAT函数 @Query("SELECT u.username FROM User u WHERE u.username LIKE CONCAT('%',:use ...

  6. instr动态模糊查询

    String sqlSearchtext = ""; if(!"".equals(model.getXzqhdm())&&model.getXz ...

  7. MySQL数据库一个字段对应多个值得模糊查询

    当一个字段想模糊查询出多个字段的时候,正常情况下一般会这么作 select * from a where name like 'a%' or name like 'b%' ....or ...; 但是 ...

  8. MySQL数据库一个字段对应多个值得模糊查询和多个字段对应一个模糊查询

    当一个字段想模糊查询出多个字段的时候,正常情况下一般会这么作 1 select * from a where name like 'a%' or name like 'b%' ....or ...; ...

  9. mysql 实行模糊查询 一个输入值匹配多个字段和多个输入值匹配一个字段

    mysql 实行模糊查询  一个输入值匹配多个字段 MySQL单表多字段模糊查询可以通过下面这个SQL查询实现 为啥一定要150字以上  真的麻烦  还不让贴代码了 SELECT * FROM `ma ...

随机推荐

  1. CentOS虚拟机不能联网状况下yum方式从本地安装软件包(转载的)

    大家都知道yum是linux下一个非常好用的软件安装/卸载软件,它方便操作,而且最厉害的是可以解决令人头疼的包依赖关系.但是若是你的linux不能联网,若想使用yum安装软件,可以依照下面的方法. 1 ...

  2. msyql 字节问题

    MySQL 数据库的varchar类型在4.1以下的版本中的最大长度限制为255,其数据范围可以是0~255或1~255(根据不同版本数据库来定).在 MySQL5.0以上的版本中,varchar数据 ...

  3. 什么是mata标签

    <meta> 元素可提供有关页面的元信息(meta-information),比如针对搜索引擎和更新频度的描述和关键词. <meta> 标签位于文档的头部,不包含任何内容.&l ...

  4. 一个小程序,时间util

    比较时间,如果此时间是今天的显示时间点,今天以前显日期 public String getTime(Date time){               SimpleDateFormat dateFor ...

  5. Linux Epoll介绍和程序实例

    Linux Epoll介绍和程序实例 1. Epoll是何方神圣? Epoll但是当前在Linux下开发大规模并发网络程序的热门人选,Epoll 在Linux2.6内核中正式引入,和select类似, ...

  6. C primer plus 读书笔记第十二章

    C的强大功能之一在于它允许我们控制程序的细节.C的内存管理系统正是这种控制能力的例子.它通过让我们决定哪些函数知道哪些变量以及一个变量在程序中存在多长时间来实现这些控制. 1.存储类及其说明符 主要的 ...

  7. 细说Lucene源码(一):索引文件锁机制

    大家都知道,在多线程或多进程的环境中,对统一资源的访问需要特别小心,特别是在写资源时,如果不加锁,将会导致很多严重的后果,Lucene的索引也是如此,lucene对索引的读写分为IndexReader ...

  8. troubleshooting tools in JDK 7--转载

    This chapter describes in detail the troubleshooting tools that are available in JDK 7. In addition, ...

  9. [转] 怎样快速而优雅地遍历 JavaScript 数组

    我们一般用循环来遍历数组,而循环一直是 JavaScript 性能问题的常见来源,有时循环用得不好会严重降低代码的运行速度.例如,遍历数组时,我们会很自然地写出下面这种代码: // 未优化的代码1 v ...

  10. [转] Java中继承thread类与实现Runnable接口的区别

    Java中线程的创建有两种方式: 1.  通过继承Thread类,重写Thread的run()方法,将线程运行的逻辑放在其中 2.  通过实现Runnable接口,实例化Thread类 在实际应用中, ...