JPA跟mybitis比较,简单的业务搜索是方便的,但是设计到复杂的SQL搜索时,我们需要自定义SQL。

1.@Query直接写SQL,缺点是无法动态的组装条件

2.JPA的Specification对象动态组装where搜索条件

3.entityManager执行CriteriaBuilder

4.entityManger直接使用createNativeQuery,执行原生SQL。这里设计到返回结果集的承载体必须是数据库对应的实体。

这里说一个自定义的VO承接返回结果集的方法。

ProjectAttendanceEntity
    @Id@GeneratedValue(strategy = GenerationType.IDENTITY)private Long id;@Column(name = "f_id")private Long fId;@Column(name = "user_id")private Integer userId;@Column(name = "zh_name")private String zhName;@Column(name = "po_code")private String poCode;@Column(name = "po_name")private String poName;@Column(name = "punch_date")private String punchDate;@Column(name = "is_original")private String isOriginal;@Column(name = "attendance_hours")private String attendanceHours;@Column(name = "work_hours")private String workHours;@Column(name = "punch_area")private String punchArea;

结果集承接VO   (AttendancePoSzVO)

    private String poId;private String poName;private String zhName;

执行接口:

/*** 批量修改项目名称* @return*/@PostMapping("/po/sz/batch/{project}/{pn}/{ps}")public PageResultVO findBatchPoInfoByUserIdAndDate(@RequestBody List<Long> ids,@PathVariable String project,@PathVariable Integer pn,@PathVariable Integer ps){log.info("url:/po/sz/batch/"+"|param:"+ids);//通过id查询数据List<ProjectAttendanceEntity> projects = projectAttendanceEntityRepository.findByIdIn(ids);//获取SQLString sql = getSQL(projects,pn,ps);Query query = entityManager.createNativeQuery(sql);List<AttendancePoSzVO> list = query.unwrap(NativeQuery.class).setResultTransformer(Transformers.aliasToBean(AttendancePoSzVO.class)).getResultList();//初始化结果集List<DropDownVO> result = new ArrayList<>();for(AttendancePoSzVO poSz : list){result.add(new DropDownVO(poSz.getPoName(),poSz.getPoId()));}return new PageResultVO(GlobalReturnCode.SUCCESS_CODE,"SUCCESS",ps,pn,result);}/*** 组装查询SQL* @return*/public String getSQL(List<ProjectAttendanceEntity> poStatus, Integer pn, Integer ps){StringBuilder sql = new StringBuilder("SELECT DISTINCT res.po_id as poId,res.po_name as poName, GROUP_CONCAT(DISTINCT res.user_id) AS zhName ");sql.append(" FROM (");sql.append(" SELECT tt.po_name,tt.po_id,tt.user_id");sql.append(" FROM sie_sz_po_attendance_v tt ");sql.append(" WHERE");for(ProjectAttendanceEntity po : poStatus){sql.append("(tt.user_id = ").append(po.getUserId()).append(" and tt.rt_begin_date <= '").append(po.getPunchDate()).append("' and tt.rt_end_date >= '").append(po.getPunchDate()).append("') OR ");}//截掉最后一个ORsql = new StringBuilder(sql.substring(0,sql.length()-3));sql.append(" ) res");sql.append(" GROUP BY res.po_name,res.po_id");sql.append(" HAVING ");for(ProjectAttendanceEntity po : poStatus){sql.append(" INSTR(zhName,").append(po.getUserId()).append(") >0").append(" AND ");}//截取最后一个ANDsql = new StringBuilder(sql.substring(0,sql.length()-4));sql.append(" LIMIT ").append(pn).append(",").append((pn+1)*ps);return sql.toString();}

核心代码:

List<AttendancePoSzVO> list = query.unwrap(NativeQuery.class).setResultTransformer(Transformers.aliasToBean(AttendancePoSzVO.class)).getResultList();

但是这里的 setResultTransformer 已经过时了。

所以接下来寻找 setResultTransformer的替代API。

JPA自定义VO接受返回结果集(unwrap)相关推荐

  1. JPA返回自定义Vo

    JPA返回自定义VO 最近做项目用到了JPA,很多地方需要返回自定义vo,最开始用@Query注解返回自定义List<Objec[]>,在用forEach遍历存入List实在是不方便,找了 ...

  2. QueryDSL 自定义返回结果集类型

    QueryDSL 自定义返回结果集 环境 问题 分析 解决 结论 环境   开发框架使用的是springboot,持久框架使用的是spring data jpa+QueryDSL,具体版本参见下面的p ...

  3. jpa调用mysql函数_Spring data jpa 调用存储过程处理返回参数及结果集(示例代码)

    一.环境 1.此随笔内容基于spring boot整合的spring data jpa项目, 2.数据库为mysql 5.7.9版本 二.内容 1. 新建存储过程 pro_query_object B ...

  4. java查询结果自定义显示_JPA自定义对象接收查询结果集操作

    最近使用JPA的时候,碰到需要自定义查询结果集的场景,网上搜了一下,都是需要自定义方法写一大串代码实现的,太繁琐了,有那时间还不如用mybaits. 用JPA就是要尽量通过声明接口解决持久层问题,要不 ...

  5. oracle调用存储过程和函数返回结果集

    视频课:https://edu.csdn.net/course/play/7940 在程序开发中,常用到返回结果集的存储过程,这个在MySQL和sql server 里比较好处理,直接返回查询结果就可 ...

  6. C#调用ORACLE存储过程返回结果集及函数

    ORACLE段: 首先在ORACLE建立PACKAGE和PACKAGE BODY,将在这里面定义函数和存储过程返回结果集. 1:建立PACKAGE: CREATE OR REPLACE package ...

  7. Java 统一返回结果集封装

    Java 统一返回结果集封装 封装实体类 调用 封装实体类 /*** 统一返回结果集实体类* @param <T> 返回数据对象*/ @Data public class ErrorMsg ...

  8. oracle 存储过程返回,Oracle 存储过程返回结果集 (转)

    Oracle 存储过程返回结果集 (转)[@more@] 1.返回数组 (作者:/Message_Board/Send.?sendto=enhydraboy" target=_blank&g ...

  9. Spring JPA自定义SQL分页查询

    JPA自定义SQL分页查询 [存在的问题] 在使用Spring JPA原生SQL进行分页查询时存在如下问题: 1.使用List转Page工具类导致查询速度较慢,原因在于先把所有数据查询出来返回成Lis ...

最新文章

  1. 谈谈ogre中级教程中例子与appwizard冲突
  2. 搜索引擎基本原理,产品知识普及帖
  3. 使用 Carla 和 Python 的自动驾驶汽车第 2 部分 —— 控制汽车并获取传感器数据
  4. java 应用程序无法运行_关于解决浏览器无法运行小应用程序问题
  5. thinkPHP6.0 控制器请求方法延迟生效解决办法
  6. Linux基础操作及命令管理
  7. java list打乱顺序_「collections.shuffle」Collections.shuffle()打乱List - seo实验室
  8. Adobe-CC-2017 安装教程
  9. 基于小波Block-Thresholding的降噪方法
  10. 【mxGraph】源码学习:(6)mxGraphModel
  11. Android 运行程序报错:Unable to execute dex: Multiple dex files define Lcom/baidu/android/pushservice/Push
  12. Minimum supported Gradle version is 4.6. Current version is 4.4.
  13. 公众号运营的小伙伴们看过来啦!
  14. 基于MATLAB的BPSK和QPSK调制的性能比较
  15. oracle实体视图日志,Oracle案例02——ORA-12034: SCOTT.USER_TABLE 上的实体化视图日志比上次刷新后的内容新...
  16. AIX系统管理界面工具SMIT快捷方式
  17. 计算机网络第一二章多选题,计算机网络概论第一章练习题
  18. Unity3d UGUI基础控件使用(一)
  19. Win7 安装及激活方法
  20. 导向纠偏器PG-250D50W230AR、PG-400D60W320AL

热门文章

  1. WIN10+CUDA9.2+ZED双目SDK 安装教程(无人驾驶,感知)
  2. 首次使用计算机 鼠标没反应,鼠标插上灯亮没反应怎么办 鼠标常见故障如何解决...
  3. CString头文件怎么用?
  4. 基于STM32F103,SPI驱动GC9306屏幕
  5. Android应用换肤
  6. python web开发第三方库_以下属于Python中Web开发框架第三方库的是__________
  7. xtrabackup 备份与还原 mysql数据库
  8. MATLAB学习八(四):相关系数corrcoef
  9. 高德地图-兴趣点(POI)
  10. MATLAB案例-汽车雷达