Spring Boot整合QueryDSL的實(shí)現(xiàn)示例
之前研究Jooq,今天來研究一下搭配JPA的QueryDSL吧。
簡(jiǎn)介
Querydsl 是一個(gè)Java開源框架用于構(gòu)建類型安全的SQL查詢語句。它采用API代替拼湊字符串來構(gòu)造查詢語句??筛?Hibernate 和 JPA 等框架結(jié)合使用。
新建Spring Boot項(xiàng)目
。。。還說啥?
1. pom.xml
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<scope>runtime</scope>
</dependency>
<!--QueryDSL支持-->
<dependency>
<groupId>com.querydsl</groupId>
<artifactId>querydsl-apt</artifactId>
<scope>provided</scope>
</dependency>
<!--QueryDSL支持-->
<dependency>
<groupId>com.querydsl</groupId>
<artifactId>querydsl-jpa</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
<exclusions>
<exclusion>
<groupId>org.junit.vintage</groupId>
<artifactId>junit-vintage-engine</artifactId>
</exclusion>
</exclusions>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
<!-- 這個(gè)插件是為了讓程序自動(dòng)生成query type(查詢實(shí)體,命名方式為:"Q"+對(duì)應(yīng)實(shí)體名) -->
<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>
</plugins>
</build>
2. application.yml
server: port: 8888 spring: datasource: url: jdbc:mysql://IP地址:3306/querydsl?characterEncoding=UTF-8 username: 用戶名 password: 密碼 jpa: show-sql: true # 控制臺(tái)打印SQL hibernate: ddl-auto: update
3. JPAQueryFactory Bean
/**
* JPAQueryFactory Bean
* @author zhouzhaodong
*/
@Configuration
public class PeopleQueryConfig {
@Bean
public JPAQueryFactory jpaQuery(EntityManager entityManager) {
return new JPAQueryFactory(entityManager);
}
}
4. 新建實(shí)體類
/**
* 實(shí)體類
* @author zhouzhaodong
*/
@Entity
@Table(name="people")
public class People {
@Id
@Column(name="id")
@GeneratedValue
private Integer id;
@Column(name="name")
private String name;
@Column(name="age")
private Integer age;
@Column(name="address")
private String address;
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public Integer getAge() {
return age;
}
public void setAge(Integer age) {
this.age = age;
}
public String getAddress() {
return address;
}
public void setAddress(String address) {
this.address = address;
}
}
5. 新建service
/**
* service
* @author zhouzhaodong
*/
public interface PeopleService {
/**
* 根據(jù)id查詢
* @param id
* @return
*/
People selectOne(Integer id);
}
6. 新建serviceImpl
/**
* serviceImpl
* @author zhouzhaodong
*/
@Service
public class PeopleServiceImpl implements PeopleService {
@Resource
JPAQueryFactory queryFactory;
@Override
public People selectOne(Integer id) {
QPeople people = QPeople.people;
return queryFactory.selectFrom(people).where(people.id.eq(id)).fetchOne();
}
}
7. 新建controller
/**
* controller
* @author zhouzhaodong
*/
@RestController
public class PeopleController {
@Resource
PeopleService peopleService;
@RequestMapping("/selectById")
public People selectById(){
return peopleService.selectOne(0);
}
}
8. 新建repository,可以使用JPA原有的功能
/**
* 實(shí)現(xiàn)jpaRepository
* @author zhouzhaodong
*/
public interface PeopleRepository extends JpaRepository<People, Integer> {
}
9. postman測(cè)試
數(shù)據(jù)庫數(shù)據(jù)如下:

請(qǐng)求結(jié)果:
Github代碼地址:https://github.com/zhouzhaodong/springboot/tree/master/querydsl
到此這篇關(guān)于Spring Boot整合QueryDSL的實(shí)現(xiàn)示例的文章就介紹到這了,更多相關(guān)SpringBoot整合QueryDSL內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java使用Flyway實(shí)現(xiàn)數(shù)據(jù)庫版本控制的技術(shù)指南
在現(xiàn)代應(yīng)用開發(fā)中,數(shù)據(jù)庫結(jié)構(gòu)經(jīng)常隨著業(yè)務(wù)需求不斷演變,使用手動(dòng)SQL腳本管理數(shù)據(jù)庫版本,不僅容易出現(xiàn)錯(cuò)誤,還難以跟蹤和回滾,Flyway是一個(gè)強(qiáng)大的數(shù)據(jù)庫遷移工具,能夠幫助開發(fā)者高效管理和自動(dòng)化數(shù)據(jù)庫的版本控制,本文將介紹Flyway的基本功能及其在SpringBoot項(xiàng)目中的實(shí)踐2025-02-02
SpringBoot結(jié)合Quartz實(shí)現(xiàn)數(shù)據(jù)庫存儲(chǔ)
本文主要介紹了SpringBoot+Quartz+數(shù)據(jù)庫存儲(chǔ),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-01-01
Java數(shù)據(jù)結(jié)構(gòu)及算法實(shí)例:考拉茲猜想 Collatz Conjecture
這篇文章主要介紹了Java數(shù)據(jù)結(jié)構(gòu)及算法實(shí)例:考拉茲猜想 Collatz Conjecture,本文直接給出實(shí)現(xiàn)代碼,代碼中包含詳細(xì)注釋,需要的朋友可以參考下2015-06-06
Java中使用Lambda表達(dá)式和函數(shù)編程示例
這篇文章介紹了Java中使用Lambda表達(dá)式和函數(shù)編程示例,該文章會(huì)演示多個(gè)示列,分別是變量聲明上下文中的lambda、return語句上下文中的lambda、賦值上下文中的lambda、lambda在數(shù)組初始值設(shè)定項(xiàng)上下文中的用法等等,需要的朋友可以參考一下2021-10-10
springboot 實(shí)現(xiàn)bean手動(dòng)注入操作
這篇文章主要介紹了springboot 實(shí)現(xiàn)bean手動(dòng)注入操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2021-01-01
Java獲取當(dāng)?shù)氐娜粘鋈章鋾r(shí)間代碼分享
這篇文章主要介紹了Java獲取當(dāng)?shù)氐娜粘鋈章鋾r(shí)間代碼分享,國(guó)外猿友寫的一個(gè)類,需要的朋友可以參考下2014-06-06
SpringBoot自動(dòng)裝配之@Import深入講解
由于最近的項(xiàng)目需求,需要在把配置類導(dǎo)入到容器中,通過查詢,使用@Import注解就能實(shí)現(xiàn)這個(gè)功能,@Import注解能夠幫我們吧普通配置類(定義為Bean的類)導(dǎo)入到IOC容器中2023-01-01
springmvc實(shí)現(xiàn)簡(jiǎn)單的攔截器
這篇文章主要為大家詳細(xì)介紹了springmvc實(shí)現(xiàn)簡(jiǎn)單攔截器的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-05-05

