Flutter开发App的未来及其在各行业的应用潜力分析
680
2023-04-17
Spring Boot整合QueryDSL的实现示例
之前研究Jooq,今天来研究一下搭配JPA的QueryDSL吧。
简介
Querydsl 是一个java开源框架用于构建类型安全的SQL查询语句。它采用API代替拼凑字符串来构造查询语句。可跟 Hibernate 和 JPA 等框架结合使用。
新建Spring Boot项目
。。。还说啥?
1. pom.xml
&http://lt;/configuration>
2. application.yml
server:
port: 8888
spring:
datasource:
url: jdbc:mysql://IP地址:3306/querydsl?characterEncoding=UTF-8
username: 用户名
password: 密码
jpa:
show-sql: true # 控制台打印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. 新建实体类
/**
* 实体类
* @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 {
/**
* 根据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原有的功能
/**
* 实现jpaRepository
* @author zhouzhaodong
*/
public interface PeopleRepository extends JpaRepository
}
9. postman测试
数据库数据如下:
请求结果:
github代码地址:https://github.com/zhouzhaodong/springboot/tree/master/querydsl
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~