StringData JPA 是微服务框架下一款ORM框架,在微服务体系架构下,数据持久化框架,主要为SpringData JPA及Mybatis两种,这两者的具体比较,本文不做阐述,本文只简单阐述SpringData JPA的使用方法。

简介

SpringData JPA的Repository接口介绍,本文主要介绍CrudRepository、PagingAndSortingRepository、JpaSpecificationExecutor。

示例

pom.xml

<!--Springboot-web-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!--SpringData-JPA-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>
<!--mysql启动-->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<scope>runtime</scope>
</dependency>
<!--测试驱动-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>

 entity:

/*
* 数据实体,表名test_emp
*/
@Entity
@Table(name="test_emp")
public class Emp implements Serializable{
private static final long serialVersionUID = 1L;
@Id
@GeneratedValue(strategy=GenerationType.AUTO)
private Integer id;
@Column
private Integer age;
@Column
private String name;
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public Integer getAge() {
return age;
}
public void setAge(Integer age) {
this.age = age;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
@Override
public String toString() {
return "Emp [id=" + id + ", age=" + age + ", name=" + name + "]";
}
}

CrudRepository实现:

public interface EmpCrudRepository extends CrudRepository<Emp, Integer> {
/*
*Query高级查询
*/
@Query("select e from Emp e")
public List<Emp> queryAllTest();
}

PagingAndSortingRepository实现:

public interface EmpPagingAndSortingRepository extends PagingAndSortingRepository<Emp, Integer> {

}

EmpJpaSpecificationExecutor实现:

public interface EmpJpaSpecificationExecutor extends JpaSpecificationExecutor<Emp>,Repository<Emp, Integer>{

}

 CurdRepository测试:

@SpringBootTest
@RunWith(SpringRunner.class)
public class EmpCurdRepositoryTest { @Autowired
private EmpCrudRepository empCrudRepository; @Test
public void testAdd() {
Emp emp = new Emp();
emp.setAge(22);
emp.setId(1);
emp.setName("test1");
empCrudRepository.save(emp);
} @Test
public void testAddAll() {
List<Emp> emps = new ArrayList<>();
for (int i = 0; i < 10; i++) {
Emp emp = new Emp();
emp.setAge(i+20);
emp.setName("test"+i);
emps.add(emp);
}
empCrudRepository.saveAll(emps);
} /**
* Query注解使用
*/
@Test
public void testQueryAll() {
List<Emp> emps = empCrudRepository.queryAllTest();
for(Emp emp:emps) {
System.out.println(emp);
}
}
}

  PagingAndSortingRepository测试:

@SpringBootTest
@RunWith(SpringRunner.class)
public class EmpPagingAndSortingRepositoryTest { @Autowired
private EmpPagingAndSortingRepository empPagingAndSortingRepository;
@Test
public void query() {
Pageable pageable = PageRequest.of(0, 10, Direction.DESC, "id");
Iterable<Emp> emps = empPagingAndSortingRepository.findAll(pageable);
for(Emp emp:emps) {
System.out.println(emp);
}
} @Test
public void queryAll() {
Pageable pageable = PageRequest.of(0, 7, Direction.DESC, "id");
Page<Emp> result = empPagingAndSortingRepository.findAll(pageable); //查询结果是pageable对象
// Iterable<Emp> emps = empPagingAndSortingRepository.findAll(pageable); //查询结果直接是emp对象
System.out.println(result.getContent());
System.out.println(result.getNumber());
System.out.println(result.getNumberOfElements());
System.out.println(result.getTotalElements());
System.out.println(result.getTotalPages());
for(Emp emp:result.getContent()) {
System.out.println(emp);
}
}
}

  JpaSpecificationExecutor测试:

@RunWith(SpringRunner.class)
@SpringBootTest
public class EmpJpaSpecificationExecutorTest { @Autowired
private EmpJpaSpecificationExecutor empJpaSpecificationExecutor; @Test
public void test() {
Specification<Emp> spec = new Specification<Emp>() {
@Override
//多种复杂条件组合查询,属于JPA高级
public Predicate toPredicate(Root<Emp> root, CriteriaQuery<?> query, CriteriaBuilder cb) {
List<Predicate> predicates = new ArrayList<>();
Predicate p1 = cb.gt(root.get("age"), 25);
Predicate p2 = cb.lt(root.get("age"), 28);
Predicate p3 = cb.and(p1,p2);
predicates.add(p3);
return query.where(predicates.toArray(new Predicate[predicates.size()])).getRestriction();
}
}; Pageable pageable = PageRequest.of(0, 5, Direction.ASC, "id"); Page<Emp> emps = empJpaSpecificationExecutor.findAll(spec, pageable);
for (Emp emp: emps.getContent()) {
System.out.println(emp);
} }
}

  

Springboot集成SpringData JPA的更多相关文章

  1. SpringBoot整合SpringData JPA入门到入坟

    首先创建一个SpringBoot项目,目录结构如下: 在pom.xml中添加jpa依赖,其它所需依赖自行添加 <dependency> <groupId>org.springf ...

  2. SpringBoot集成jdbcTemplate/JPA

    1.pom.xml <!-- jdbcTemplate 依赖 --> <dependency> <groupId>org.springframework.boot& ...

  3. Spring Data JPA系列2:SpringBoot集成JPA详细教程,快速在项目中熟练使用JPA

    大家好,又见面了. 这是Spring Data JPA系列的第2篇,在上一篇<Spring Data JPA系列1:JDBC.ORM.JPA.Spring Data JPA,傻傻分不清楚?给你个 ...

  4. SpringBoot图文教程12—SpringData Jpa的基本使用

    有天上飞的概念,就要有落地的实现 概念十遍不如代码一遍,朋友,希望你把文中所有的代码案例都敲一遍 先赞后看,养成习惯 SpringBoot 图文教程系列文章目录 SpringBoot图文教程1「概念+ ...

  5. 带你搭一个SpringBoot+SpringData JPA的环境

    前言 只有光头才能变强. 文本已收录至我的GitHub仓库,欢迎Star:https://github.com/ZhongFuCheng3y/3y 不知道大家对SpringBoot和Spring Da ...

  6. 6.4 SpringData JPA的使用

    引言:该文档是参考尚硅谷的关于springboot教学视屏后整理而来.当然后面还加入了一些自己从网上收集整理而来的案例! 一.SpringData JPA初步使用 1. springdata简介 2. ...

  7. 【极简版】SpringBoot+SpringData JPA 管理系统

    前言 只有光头才能变强. 文本已收录至我的GitHub仓库,欢迎Star:https://github.com/ZhongFuCheng3y/3y 在上一篇中已经讲解了如何从零搭建一个SpringBo ...

  8. 尚硅谷springboot学习34-整合SpringData JPA

    SpringData简介

  9. 第11章—使用对象关系映射持久化数据—SpringBoot+SpringData+Jpa进行查询修改数据库

    SpringBoot+SpringData+Jpa进行查询修改数据库 JPA由EJB 3.0软件专家组开发,作为JSR-220实现的一部分.但它又不限于EJB 3.0,你可以在Web应用.甚至桌面应用 ...

随机推荐

  1. CRUSH map 定制实例解析

    1.提取已有的CRUSH map ,使用-o参数,ceph将输出一个经过编译的CRUSH map 到您指定的文件ceph osd getcrushmap -o crushmap.txt 2.反编译你的 ...

  2. js string 和 json 互转

    var o = JSON.parse('{"a": 8}'); JSON. stringify(o);

  3. Flask从入门到精通之Flash消息

    请求完成后,有时需要让用户知道状态发生了变化.这里可以使用确认消息.警告或者错误提醒.一个典型例子是,用户提交了有一项错误的登录表单后,服务器发回的响应重新渲染了登录表单,并在表单上面显示一个消息,提 ...

  4. [HTML] H5在webApp中的注意事项

    常用的meta标签 <!--防止手机中网页放大和缩小--> <meta name="viewport" content="width=device-wi ...

  5. python 实现视频的下载以及断点续传

    ---恢复内容开始--- 一般情况下我们使用爬虫更多的应该是爬数据或者图片吧,今天在这里和大家分享一下关于使用爬虫技术来进行视频下载的方法,不仅可以方便的下载一些体积小的视频,针对大容量的视频下载同样 ...

  6. php if 的实现

    简单分析下php中的分支背后的实现 <?php ){ echo "a"; }else{ echo "b"; } 1.语法分析 unticked_state ...

  7. Ubuntu Cannot run program "../SDK/build-tools/xxx/aapt": erro = 2 No such file or directory

    64位ubuntu Android Studio  Gradle编译时出现如下报错: java.io.IOException: Cannot run program "/home/king/ ...

  8. 添加或删除 HTML dom元素

    添加或删除 HTML dom元素 创建新的 HTML 元素 如需向 HTML DOM 添加新元素,您必须首先创建该元素(元素节点),然后向一个已存在的元素追加该元素. <div id=" ...

  9. h5移动端聊天室|仿微信界面聊天室|h5多人聊天室

    今年的FIFA世界杯甚是精彩,最近兴致高涨就利用HTML5开发了一个手机端仿微信界面聊天室,该h5聊天室采用750px全新伸缩flex布局,以及使用rem响应式配合fontsize.js,页面弹窗则是 ...

  10. 监督学习——随机梯度下降算法(sgd)和批梯度下降算法(bgd)

    线性回归 首先要明白什么是回归.回归的目的是通过几个已知数据来预测另一个数值型数据的目标值. 假设特征和结果满足线性关系,即满足一个计算公式h(x),这个公式的自变量就是已知的数据x,函数值h(x)就 ...