IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Java知识库 -> Spring data jpa 使用Specification实现动态查询 -> 正文阅读

[Java知识库]Spring data jpa 使用Specification实现动态查询

Spring data jpa 使用Specification实现动态查询

在开发过程中,存在一个查询方法会收到不同参数的情况,下面这段代码可以用jpa实现动态查询,完全面向对象,在复杂查询方面虽然不及mybatis 灵活,但仍然有其可取之处, 但是我遇到的问题就是,我无法将这样的代码封装起来用于不同的实体类的查询,因为传入的对象无法确定,反射功能无法实现。希望有人能一起探讨一下。

@RestController
@RequestMapping("/productions")
public class ProductionController {
    @Resource
    ProductionRepository productionRepository;
    @GetMapping("{currentPage}/{pageSize}")
    public RestBean<Page<Production>> dymamicEnquire(@RequestBody Production production, @PathVariable int currentPage, @PathVariable int pageSize) throws InvocationTargetException, IllegalAccessException, NoSuchMethodException {
        //通过反射获取实体类的全部属性
        Field[] fields = Production.class.getDeclaredFields();
        //构造分页对象
        Pageable pageable = PageRequest.of(currentPage,pageSize, Sort.Direction.DESC,"id");
        //匿名内部类的方式构造Specification对象,其实可以用Lambda表达式,格式会更简单,但是不便于理解
        Specification<Production> specification = new Specification() {
            @SneakyThrows
            @Override
            public Predicate toPredicate(Root root, CriteriaQuery cq, CriteriaBuilder cb) {
                //新建一个查询条件数组
                List<Predicate> predicates = new ArrayList<>();
                //通过使用Apache的工具类将实体转换成map
                Map<String,String> conditions = BeanUtils.describe(production);
                for (int i = 0; i < fields.length; i++) {
                    //设置实体类属性可访问
                    fields[i].setAccessible(true);
                    String name = fields[i].getName();
                    //添加需要的查询条件
                    if (conditions.containsKey(name)&&(!ObjectUtils.isEmpty(conditions.get(name)))){
                        predicates.add(cb.equal(root.get(name), conditions.get(name)));
                    }
                }
                return cq.where(predicates.toArray(new Predicate[predicates.size()])).getRestriction();
            }
        };
        //查询
        Page<Production>list= productionRepository.findAll(specification,pageable);
        //封装返回对象
        RestBean bean = new RestBean(true,currentPage,pageSize,200,"分页查询成功",list);
        return bean;

    }


  }
  Java知识库 最新文章
计算距离春节还有多长时间
系统开发系列 之WebService(spring框架+ma
springBoot+Cache(自定义有效时间配置)
SpringBoot整合mybatis实现增删改查、分页查
spring教程
SpringBoot+Vue实现美食交流网站的设计与实
虚拟机内存结构以及虚拟机中销毁和新建对象
SpringMVC---原理
小李同学: Java如何按多个字段分组
打印票据--java
上一篇文章      下一篇文章      查看所有文章
加:2022-03-13 21:36:26  更:2022-03-13 21:37:05 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 8:52:26-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码