jpa基于ExampleMatcher,Example实现动态筛选,模糊查询,分页,排序,时间范围筛选
简介:
素材来源于网络,加入个人理解进行组装,减少后台代码量(偷懒),在代码配置化得路上远行
满足条件:
基础条件赛选(模糊查询)
范围筛选(此文针对于时间,其他类似)
基础分页排序等
优点:代码一次成型,减少代码维护成本(非个性化需求)
缺点:范围筛选部分代码量较多,不易理解
表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实现动态筛选,模糊查询,分页,排序,时间范围筛选相关推荐
- ajax jsp模糊查询源码,Ajax动态执行模糊查询功能
Ajax动态执行模糊查询功能 内容精选 换一换 Profiling采集的数据较多,同时解析后展示的性能指标项也比较多,为方便用户快捷查找到具体性能指标的含义,提供命令行查询功能:不包含metric_n ...
- 动态sql模糊查询和分页
文章目录 动态sql 模糊查询 查询返回结果集的处理 分页 动态sql BookMapper xml bookservice 测试: MapperSql.test 运行: 模糊查询 BookMappe ...
- 新闻发布系统——模糊查询分页与主题分页
效果图(模糊查询分页) 实现代码(java部分) <ul class="classlist"><%//获取模糊查询的关键字String str = request ...
- MVC分层+JDBC+数据库+Servlet实现JSP文件上传和显示+模糊查询+分页
本文章主要介绍了一个简单的实例:用简单的MVC分层思想,使用数据库在web界面进行增删改查,以及上传,模糊查询+分页的实现. 1.util层(数据库连接管理) :连接数据库需要导包:mysql-con ...
- 动态SQL 模糊查询 联表查询
1. 正文 1. set标签 和 foreach标签 trim标签 sql片段 2. mybatis映射文件处理特殊字符. 3. mybatis完成模糊查询. 4. 联表查询 2. 动态sql 2.1 ...
- sql语句模糊查询以及时间区间筛选
最近做了个接口参数是是查询数据库的项目,恶补了一下sql语句 模糊查询(最简单写法%任意%) select * from log where seatname like'%192.168.15.121 ...
- Mybatis:Example类的使用--基本增删改查,模糊查询,排序,or,分页查询
MyBatis Generator 介绍 MyBatis Generator:简称MBG,是一个专门为MyBatis框架使用者定制的代码生成器,可以快速的根据表生成对应的映射文件,接口,以及bean类 ...
- 07--MySQL自学教程:DQL(Data Query Language:数据库查询语言)简介、基础查询、条件查询、模糊查询以及排序(一)
1. DQL(Data Query Language:数据库查询语言)知识点概览 DQL(Data Query Language:数据库查询语言): 用来查询数据(记录),不会对数据进行改变,而是让数 ...
- Mybatis-增删改查模糊查询分页注解(普通类型参数、引用类型参数、Map类型参数)
代码地址https://www.lanzouw.com/ihOmnwdtbrc 请先看项目目录结构,然后再写代码.target是编译后的输出目录,只需要保证src目录目录一致就行. 1.创建数据库my ...
最新文章
- 荣耀com.huawei.android,荣耀阅读(com.huawei.hnreader) - 8.1.0.309 - 应用 - 酷安
- C语言再学习-- readelf、objdump、nm使用详解
- JDK 监控和故障处理工具总结
- 如何降低90%Java垃圾回收时间?以阿里HBase的GC优化实践为例
- elementui在vue校验表单失效的原因之一(当表单含有一到多个对象)
- 第二十二篇 玩转数据结构——构建动态数组
- 前端学习(1171):includes方法
- matlab里dcgain,制系统的时域分析
- 算法复习——迭代加深搜索(骑士精神bzoj1085)
- 不止操作系统,智能手机才更需要开源!
- 浅谈==和equals
- 清华大学2017届本科毕业典礼演讲——做有思想的行者
- 第四章 数学规划模型
- IEEE Access 期刊投稿
- 关关小说采集器规则正则表达式方法
- 两个月快速通过软考高项(信息系统项目管理师)备考技巧
- JAVA中解析XML和书写XML
- 大O记法-BigO notation
- 新版悟能口罩预约小程序源码V1.1.1
- 如何优雅地管理微信数据库?
热门文章
- 在线视频直播类app软件如何开发?
- 阿里云账号将个人实名认证变更为企业实名认证的步骤
- html中加载图片失败,图片加载失败如何用默认图片代替
- PTA:7-106 愿天下有情人都是失散多年的兄妹 (25分)(bfs,dfs)
- initWithFormat 和stringWithFormat的区别
- Temu、亚马逊、虾皮等跨境电商平台小白怎么快速提升店铺权重和产品销量?
- 乔布斯的13句经典妙语
- python 的csr_python – 设置csr_matrix行
- NPDP产品经理认证:产品营销组合的4P管理
- MySQL数据库——day26 数据库安装,卸载,概念,msq的介绍,安装,连接,DDL,DML,DQL模糊查询,字段控制(别名和运算),排序,聚合函数,分组查询(where和having),分页查询