Spring Boot整合QueryDSL的實(shí)現(xiàn)示例
之前研究Jooq,今天來(lái)研究一下搭配JPA的QueryDSL吧。
簡(jiǎn)介
Querydsl 是一個(gè)Java開(kāi)源框架用于構(gòu)建類型安全的SQL查詢語(yǔ)句。它采用API代替拼湊字符串來(lái)構(gòu)造查詢語(yǔ)句。可跟 Hibernate 和 JPA 等框架結(jié)合使用。
新建Spring Boot項(xiàng)目
。。。還說(shuō)啥?
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ù)庫(kù)數(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實(shí)現(xiàn)經(jīng)典游戲坦克大戰(zhàn)的示例代碼
小時(shí)候大家都玩過(guò)坦克大戰(zhàn)吧,熟悉的旋律和豐富的關(guān)卡陪伴了我們一整個(gè)寒暑假。本文將通過(guò)Java+Swing實(shí)現(xiàn)這一經(jīng)典游戲,感興趣的可以學(xué)習(xí)一下2022-01-01Mybatis-Plus條件構(gòu)造器select方法返回指定字段方式
這篇文章主要介紹了Mybatis-Plus條件構(gòu)造器select方法返回指定字段方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-06-06Springboot單體架構(gòu)http請(qǐng)求轉(zhuǎn)換https請(qǐng)求來(lái)支持微信小程序調(diào)用接口
這篇文章主要介紹了Springboot單體架構(gòu)http請(qǐng)求轉(zhuǎn)換https請(qǐng)求來(lái)支持微信小程序調(diào)用接口,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-11-11springboot配置logback日志管理過(guò)程詳解
這篇文章主要介紹了springboot配置logback日志管理過(guò)程詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-09-09Java中隨機(jī)數(shù)的產(chǎn)生方式與原理詳解
這篇文章主要介紹了Java中隨機(jī)數(shù)的產(chǎn)生方式與原理詳解的相關(guān)資料,需要的朋友可以參考下2016-11-11Java簡(jiǎn)單實(shí)現(xiàn)UDP和TCP的示例
下面小編就為大家?guī)?lái)一篇Java簡(jiǎn)單實(shí)現(xiàn)UDP和TCP的示例。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-11-11