博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
QueryDSL
阅读量:5287 次
发布时间:2019-06-14

本文共 4808 字,大约阅读时间需要 16 分钟。

1.问题的提出

  有的人可能会遇到这样的代码,看了后难以忍受,缺点如下所述:

    1. 返回类型Object[]数组,至于每一个下标对应哪个字段,没法直观的看到,例如object[11]是什么类型? 字段名是什么? 这个就无法直观得知 .
    2. sql中复杂的关系导致不可维护,每一个接手的人都要研究sql半天
    3. 该种动态拼接条件方法导致类似的代码会大量重复,所以IDEA打开的时候黄了半边天.
    4. 该查询为分页查询,这样写的话,还要再copy一个count查询才能拿到总数,无疑又是代码重复.
    5. JPA之类框架目的就是少些原生sql语句,大量这样的操作的话,还不如使用dbUtil这样的工具类查询.
1  @Override 2     public List
findByPcardCardOrder( 3 PcardCardOrder pcardCardOrder,String applyInstName2,Integer page, Integer rows) { 4 StringBuffer sql = new StringBuffer( 5 "SELECT p.*" 6 +",p2.vcard_make_des" 7 +",p3.cardnum_rule_id,p3.vtype_nm" 8 +",p4.cn_card_bin,p4.cn_nm" 9 +",p5.inst_id,p5.inst_name,p5.apply_range,p5.card_name,p5.card_type,p5.bin_card_material"10 +",p6.inst_name AS apply_inst_name "11 +",p7.inst_name AS apply_inst_name2"12 + ",p8.inst_name as receive_inst_name"13 + " FROM "14 +" tbl_pcard_card_order p LEFT JOIN tbl_pcard_vcard_make p2 ON p.make_id = p2.vcard_make_id"15 +" LEFT JOIN tbl_pcard_vtype p3 ON p2.vcard_make_vtype_id=p3.vtype_id"16 +" LEFT JOIN tbl_pcard_cardnum_rule p4 ON p3.cardnum_rule_id=p4.cn_id"17 +" LEFT JOIN tbl_pcard_cardbin p5 ON p4.cn_card_bin=p5.card_bin"18 +" LEFT JOIN tbl_pcard_institution p6 ON p5.apply_range=p6.inst_id"19 +" LEFT JOIN tbl_pcard_institution p7 ON p.apply_inst_id=p7.inst_id"20 +" LEFT JOIN tbl_pcard_institution p8 ON p.receive_inst=p8.inst_id"21 +" WHERE 1=1 ");22 int i = 1;23 Map
map = new HashMap
();24 25 if (!StringUtils.isEmpty(pcardCardOrder.getCordId())) {26 sql.append(" and p.cord_id=");27 sql.append("?" + i);28 map.put(i + "", pcardCardOrder.getCordId());29 i++;30 }31 if (!StringUtils.isEmpty(pcardCardOrder.getAppointMchtcard())) {32 sql.append(" and p.appoint_mchtcard=");33 sql.append("?" + i);34 map.put(i + "", pcardCardOrder.getAppointMchtcard());35 i++;36 }37 38 if (!StringUtils.isEmpty(pcardCardOrder.getMakeId())) {39 sql.append(" and p.make_id like ");40 sql.append("?" + i);41 map.put(i + "","%%"+ pcardCardOrder.getMakeId()+"%%");42 i++;43 }44 45 if (!StringUtils.isEmpty(applyInstName2)) {46 sql.append(" and p7.inst_name like ");47 sql.append("?"+i);48 map.put(i+"","%%"+applyInstName2+"%%");49 i++;50 }51 52 sql.append(" order by p.ct_dm desc");53 Query query = entityManager.createNativeQuery(sql.toString());54 for (String key : map.keySet()) {55 query.setParameter(key, map.get(key));56 }57 if (page != null && rows != null) {58 query.setFirstResult(rows * (page - 1));59 query.setMaxResults(rows);60 }61 return query.getResultList();62 }
Problem Code

 

2.学习QueryDSL

  而QueryDSL就可以避免上面全部的问题,在解决问题之前先学习如何使用 .

  2.1 QueryDSL简介

    1. QueryDSL仅仅是一个通用的查询框架,专注于通过Java API构建类型安全的SQL查询。
    2. QueryDSL可以通过一组通用的查询API为用户构建出适合不同类型ORM框架或者是SQL的查询语句,也就是说QueryDSL是基于各种ORM框架以及SQL之上的一个通用的查询框架。
    3. 借助QueryDSL可以在任何支持的ORM框架或者SQL平台上以一种通用的API方式来构建查询。目前QueryDSL支持的平台包括JPA,JDO,SQL,Java Collections,RDF,Lucene,Hibernate Search。
    4. 官网地址:

  2.2配置到项目

    首先对于queryDSL有两个版本,com.mysema.querydslcom.querydsl,前者是3.X系列,后者是4.X系列,这里使用的是后者.

    第一步: Maven引入依赖

com.querydsl
querydsl-jpa
${querydsl.version}
com.querydsl
querydsl-apt
${querydsl.version}
provided

    第二步: 加入插件,用于生成查询实例

com.mysema.maven
apt-maven-plugin
1.1.3
process
target/generated-sources/java
com.querydsl.apt.jpa.JPAAnnotationProcessor

    执行mvn compile之后,可以找到该target/generated-sources/java,然后IDEA标示为源代码目录即可.

     

借鉴链接:https://www.jianshu.com/p/2b68af9aa0f5

共同学习,共同进步,若有补充,欢迎指出,谢谢!

转载于:https://www.cnblogs.com/dengguangxue/p/10496273.html

你可能感兴趣的文章
博客园博客插入公式
查看>>
hdu 1028 Ignatius and the Princess III(母函数入门+模板)
查看>>
Ubuntu下配置安装telnet server
查看>>
Codeforces 235 E Number Challenge
查看>>
ubuntu 常见命令整理
查看>>
EJBCA安装教程+postgresql+wildfly10
查看>>
(五十四)涂鸦的实现和截图的保存
查看>>
配置EditPlus使其可以编译运行java程序
查看>>
java中的占位符\t\n\r\f
查看>>
MySQL通过frm 和 ibd 恢复数据过程
查看>>
SRS源码——Listener
查看>>
Java面向对象抽象类案例分析
查看>>
对SPI、IIC、IIS、UART、CAN、SDIO、GPIO的解释
查看>>
Thymeleaf模板格式化LocalDatetime时间格式
查看>>
庖丁解“学生信息管理系统”
查看>>
Pyltp使用
查看>>
其他ip无法访问Yii的gii,配置ip就可以
查看>>
php做的一个简易爬虫
查看>>
x的x次幂的值为10,求x的近似值
查看>>
jquery获取html元素的绝对位置和相对位置的方法
查看>>