2018-07-07 | QueryDSL | UNLOCK

让JPA 飞 - QueryDSL

jpa是什么?

JPA由EJB 3.0软件专家组开发,作为JSR-220实现的一部分。但它又不限于EJB 3.0,你可以在Web应用、甚至桌面应用中使用。JPA的宗旨是为POJO提供持久化标准规范,由此可见,经过这几年的实践探索,能够脱离容器独立运行,方便开发和测试的理念已经深入人心了。Hibernate3.2+、TopLink 10.1.3以及OpenJPA都提供了JPA的实现。

以上 来自 百度百科

既然 JPA 只是 java的一种规范,那么肯定需要厂家来支持 它的规范,我们来看看哪些厂家实现了它的规范。

  1. Hibernate
  2. Spring-JPA
  3. OpenJPA

其实我们在项目中用得比较多得就是hibernate 和 spring-jpa ,但是今天我们的主角还是 spring-jpa

尽管 spring-jpa 已经封装了底层的一些处理,但是用起来 还是有些繁琐,在工作中,我就发现了 一个好东西–QueryDSL。

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. 官网地址:点击进入

配置到项目

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

第一步:Maven引入依赖:

1
2
3
4
5
6
7
8
9
10
11
12
13
<!--query dsl-->
<dependency>
<groupId>com.querydsl</groupId>
<artifactId>querydsl-jpa</artifactId>
<version>${querydsl.version}</version>
</dependency>
<dependency>
<groupId>com.querydsl</groupId>
<artifactId>querydsl-apt</artifactId>
<version>${querydsl.version}</version>
<scope>provided</scope>
</dependency>
<!--query dsl end-->

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

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
<!--该插件可以生成querysdl需要的查询对象,执行mvn compile即可-->
<plugin>
<groupId>com.mysema.maven</groupId>
<artifactId>apt-maven-plugin</artifactId>
<version>1.1.3</version>
<executions>
<execution>
<goals>
<goal>process</goal>
</goals>
<configuration>
<outputDirectory>target/generated-sources/java</outputDirectory>
<processor>com.querydsl.apt.jpa.JPAAnnotationProcessor</processor>
</configuration>
</execution>
</executions>
</plugin>

APT插件会自动生成 Q开头的实体
用法如下

1
2
3
4
5
6
@Override
public SanitationOrder findOneOrder(String orderId) {
BooleanExpression eq = QSanitationOrder.sanitationOrder.orderId.eq(orderId);
SanitationOrder one = sanitationOrderRepository.findOne(eq);
return one;
}

还有更多强大用法,大家可以去搜搜,我这里 只是分享下 这个 好东西

评论加载中