简介:

素材来源于网络,加入个人理解进行组装,减少后台代码量(偷懒),在代码配置化得路上远行

满足条件:

基础条件赛选(模糊查询)

范围筛选(此文针对于时间,其他类似)

基础分页排序等

优点:代码一次成型,减少代码维护成本(非个性化需求)

缺点:范围筛选部分代码量较多,不易理解

表sql:

CREATE TABLE `hospital` (
  `hospital_id` int(11) NOT NULL AUTO_INCREMENT COMMENT '医院ID',
  `hospital_name` varchar(50) CHARACTER SET utf8 COLLATE utf8_bin NOT NULL COMMENT '医院名称',
  `hospital_address` varchar(255) CHARACTER SET utf8 COLLATE utf8_bin NOT NULL COMMENT '医院地址',
  `longitude` decimal(10,0) DEFAULT NULL COMMENT '医院经度',
  `dimensionality` decimal(10,0) NOT NULL COMMENT '医院维度',
  `create_by` int(11) DEFAULT NULL COMMENT '创建人',
  `create_time` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  `update_by` int(11) DEFAULT NULL COMMENT '修改人',
  `update_time` timestamp NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '修改时间',
  PRIMARY KEY (`hospital_id`)
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='医院表';

INSERT INTO hospital (hospital_id, hospital_name, hospital_address, longitude, dimensionality, create_by, create_time, update_by, update_time) VALUES(1, '太平大药房(新华路店)', '天津市和平区新华路203号', 23, 46, 1, '2022-04-15 10:08:40', 1, '2022-04-15 10:08:44');
INSERT INTO hospital (hospital_id, hospital_name, hospital_address, longitude, dimensionality, create_by, create_time, update_by, update_time) VALUES(2, '和平医药(和平大药房)', '天津和平区南市街多伦道226号药店', 56, 447, 1, '2022-04-15 10:19:31', 1, '2022-04-15 10:19:37');

实体类创建,参数类创建,此处也可用实体类做参数类(个人喜好)

jpa实现类创建

public interface HospitalRepo extends JpaRepository<Hospital, Integer> {public Hospital findTopByHospitalId(Integer id);Page<Hospital> queryByExampleWithRange(Example example, List<Range<Hospital>> ranges, Pageable pageable);}

参数类继承了分页实现,此处为自己编辑书写,并加入字段过滤条件属性(后面会介绍)

@Data
public class PageAndSortReq {private Integer page;private Integer size;private List<Order> sort;@ApiModelProperty(value = "字段过滤条件", required = true)private List<MatcherReq> MatcherList;@Data@Accessors(chain = true)public static class MatcherReq {@ApiModelProperty(value = "字段码", required = true)private String name;@ApiModelProperty(value = "过滤类型:E:根据后缀模糊查询B:根据包含模式查询A:根据前缀模糊查询", required = true)private String type;}public Pageable getPageable() {List<Sort.Order> sortOrders = new ArrayList<>();if (page == null) {page = 0;}if (size == null) {size = 20;}if (sort != null && sort.size() > 0) {for (Order order : sort) {sortOrders.add(new Sort.Order(Sort.Direction.valueOf(order.getDirection()), order.getProperty()));}return PageRequest.of(page, size, Sort.by(sortOrders));} else {return PageRequest.of(page, size);}}public static class Order {private String direction;private String property;public String getDirection() {return direction;}public Order setDirection(String direction) {this.direction = direction;return this;}public String getProperty() {return property;}public Order setProperty(String property) {this.property = property;return this;}}public Integer getPage() {return page;}public PageAndSortReq setPage(Integer page) {this.page = page;return this;}public Integer getSize() {return size;}public PageAndSortReq setSize(Integer size) {this.size = size;return this;}public List<Order> getSort() {return sort;}public PageAndSortReq setSort(List<Order> sort) {this.sort = sort;return this;}
}

范围筛选可参考地址,上面有源码地址(源码一扒直接能用)https://www.jb51.net/article/117163.htmhttps://www.jb51.net/article/117163.htm基于时间筛选做了封装(减少代码量),基于考虑大部分筛选用createTime,updateTime,如下

@Override
public Page<Hospital> queryHospital(Integer userId, HospitalParam hospitalParam) throws Exception {Hospital hospital=new Hospital();//页面传参放入实体,用于筛选BeanUtils.copyProperties(hospitalParam, hospital);ExampleMatcher matcher=ExampleMatcher.matchingAll();List<PageAndSortReq.MatcherReq> matcherList=hospitalParam.getMatcherList();//此处为字段筛选条件,PageAndSortReq 中有定义,优点(减少代码修改,条件由页面决定)if(matcherList.size()>0){matcher =TimeRange.addExampleMatcher(matcher,matcherList);}Example example = Example.of(hospital, matcher);//时间字段为参数类中定义,满足大部分条件,缺点:其他字段时间需进行书写List<Range<Hospital>> rangeList= TimeRange.addTime(hospitalParam.getStartTime(),hospitalParam.getEndTime(),hospitalParam.getStartUpdateTime(),hospitalParam.getEndUpdateTime());return hospitalRepo.queryByExampleWithRange(example,rangeList,hospitalParam.getPageable());
}

TimeRange为自己封装得类

public class TimeRange {//时间筛选封装,也可根据实际情况修改public static <T>List<Range<T>> addTime(Timestamp startDate, Timestamp endDate, Timestamp startUpdateDate, Timestamp endUpdateDate){List<Range<T>> ranges = newArrayList();if(startDate!=null && endDate!=null) {Range<T> createRange = new Range<T>("createTime", startDate, endDate);ranges.add(createRange);}if(startUpdateDate!=null && endUpdateDate!=null) {Range<T> updateRange = new Range<T>("updateTime", startUpdateDate, endUpdateDate);ranges.add(updateRange);}return ranges;}//字段过滤条件public static ExampleMatcher addExampleMatcher(ExampleMatcher matcher,List<PageAndSortReq.MatcherReq> matcherList){for (PageAndSortReq.MatcherReq matcherReq:matcherList){if(matcherReq.getType().equals("A")){matcher=matcher.withMatcher(matcherReq.getName(), ExampleMatcher.GenericPropertyMatcher::startsWith);}else if(matcherReq.getType().equals("B")){matcher=matcher.withMatcher(matcherReq.getName(), ExampleMatcher.GenericPropertyMatcher::contains);}else if(matcherReq.getType().equals("E")){matcher=matcher.withMatcher(matcherReq.getName(), ExampleMatcher.GenericPropertyMatcher::endsWith);}else {matcher=matcher.withMatcher(matcherReq.getName(), ExampleMatcher.GenericPropertyMatcher::contains);}}return matcher;}
}

jpa基于ExampleMatcher,Example实现动态筛选,模糊查询,分页,排序,时间范围筛选相关推荐

  1. ajax jsp模糊查询源码,Ajax动态执行模糊查询功能

    Ajax动态执行模糊查询功能 内容精选 换一换 Profiling采集的数据较多,同时解析后展示的性能指标项也比较多,为方便用户快捷查找到具体性能指标的含义,提供命令行查询功能:不包含metric_n ...

  2. 动态sql模糊查询和分页

    文章目录 动态sql 模糊查询 查询返回结果集的处理 分页 动态sql BookMapper xml bookservice 测试: MapperSql.test 运行: 模糊查询 BookMappe ...

  3. 新闻发布系统——模糊查询分页与主题分页

    效果图(模糊查询分页) 实现代码(java部分) <ul class="classlist"><%//获取模糊查询的关键字String str = request ...

  4. MVC分层+JDBC+数据库+Servlet实现JSP文件上传和显示+模糊查询+分页

    本文章主要介绍了一个简单的实例:用简单的MVC分层思想,使用数据库在web界面进行增删改查,以及上传,模糊查询+分页的实现. 1.util层(数据库连接管理) :连接数据库需要导包:mysql-con ...

  5. 动态SQL 模糊查询 联表查询

    1. 正文 1. set标签 和 foreach标签 trim标签 sql片段 2. mybatis映射文件处理特殊字符. 3. mybatis完成模糊查询. 4. 联表查询 2. 动态sql 2.1 ...

  6. sql语句模糊查询以及时间区间筛选

    最近做了个接口参数是是查询数据库的项目,恶补了一下sql语句 模糊查询(最简单写法%任意%) select * from log where seatname like'%192.168.15.121 ...

  7. Mybatis:Example类的使用--基本增删改查,模糊查询,排序,or,分页查询

    MyBatis Generator 介绍 MyBatis Generator:简称MBG,是一个专门为MyBatis框架使用者定制的代码生成器,可以快速的根据表生成对应的映射文件,接口,以及bean类 ...

  8. 07--MySQL自学教程:DQL(Data Query Language:数据库查询语言)简介、基础查询、条件查询、模糊查询以及排序(一)

    1. DQL(Data Query Language:数据库查询语言)知识点概览 DQL(Data Query Language:数据库查询语言): 用来查询数据(记录),不会对数据进行改变,而是让数 ...

  9. Mybatis-增删改查模糊查询分页注解(普通类型参数、引用类型参数、Map类型参数)

    代码地址https://www.lanzouw.com/ihOmnwdtbrc 请先看项目目录结构,然后再写代码.target是编译后的输出目录,只需要保证src目录目录一致就行. 1.创建数据库my ...

最新文章

  1. 荣耀com.huawei.android,荣耀阅读(com.huawei.hnreader) - 8.1.0.309 - 应用 - 酷安
  2. C语言再学习-- readelf、objdump、nm使用详解
  3. JDK 监控和故障处理工具总结
  4. 如何降低90%Java垃圾回收时间?以阿里HBase的GC优化实践为例
  5. elementui在vue校验表单失效的原因之一(当表单含有一到多个对象)
  6. 第二十二篇 玩转数据结构——构建动态数组
  7. 前端学习(1171):includes方法
  8. matlab里dcgain,制系统的时域分析
  9. 算法复习——迭代加深搜索(骑士精神bzoj1085)
  10. 不止操作系统,智能手机才更需要开源!
  11. 浅谈==和equals
  12. 清华大学2017届本科毕业典礼演讲——做有思想的行者
  13. 第四章 数学规划模型
  14. IEEE Access 期刊投稿
  15. 关关小说采集器规则正则表达式方法
  16. 两个月快速通过软考高项(信息系统项目管理师)备考技巧
  17. JAVA中解析XML和书写XML
  18. 大O记法-BigO notation
  19. 新版悟能口罩预约小程序源码V1.1.1
  20. 如何优雅地管理微信数据库?

热门文章

  1. 在线视频直播类app软件如何开发?
  2. 阿里云账号将个人实名认证变更为企业实名认证的步骤
  3. html中加载图片失败,图片加载失败如何用默认图片代替
  4. PTA:7-106 愿天下有情人都是失散多年的兄妹 (25分)(bfs,dfs)
  5. initWithFormat 和stringWithFormat的区别
  6. Temu、亚马逊、虾皮等跨境电商平台小白怎么快速提升店铺权重和产品销量?
  7. 乔布斯的13句经典妙语
  8. python 的csr_python – 设置csr_matrix行
  9. NPDP产品经理认证:产品营销组合的4P管理
  10. MySQL数据库——day26 数据库安装,卸载,概念,msq的介绍,安装,连接,DDL,DML,DQL模糊查询,字段控制(别名和运算),排序,聚合函数,分组查询(where和having),分页查询