源码地址:https://github.com/877148107/springboot_integrate
官方文档:https://docs.spring.io/spring-data/jpa/docs/2.2.4.RELEASE/reference/html/#reference
-
Spring Data
Spring Data的任务是为数据访问提供一个熟悉且一致的,基于Spring的编程模型,同时仍保留基础数据存储的特殊特征。
它使使用数据访问技术,关系和非关系数据库,map-reduce框架以及基于云的数据服务变得容易。这是一个总括项目,其中包含许多特定于给定数据库的子项目。这些项目是通过与这些令人兴奋的技术背后的许多公司和开发人员共同开发的。
-
Spring Data主要模块
-
Spring Data Commons-每个Spring Data模块的核心Spring概念。
-
Spring Data JDBC -Spring Data存储库对JDBC的支持。
-
Spring Data JDBC Ext-支持标准JDBC的数据库特定扩展,包括对Oracle RAC快速连接故障转移的支持,对AQ JMS的支持以及对使用高级数据类型的支持。
-
Spring Data JPA-对JPA的Spring Data存储库支持。
-
Spring Data KeyValue -
Map
基于库和SPI轻松建立键值存储一个Spring数据模块。 -
Spring Data LDAP -Spring数据存储库对Spring LDAP的支持。
-
Spring Data MongoDB - 基于Spring的对象文档支持和存储库。
-
Spring Data Redis-轻松配置和从Spring应用程序访问Redis。
-
Spring Data REST- Spring Data存储库导出为超媒体驱动的RESTful资源。
。。。。。https://spring.io/projects/spring-data
-
Spring Data特点
SpringData为我们提供使用统一的API来对数据访问层进行操作;这主要是Spring DataCommons项目来实现的。Spring Data Commons让我们在使用关系型或者非关系型数据访问技术时都基于Spring提供的统一标准,标准包含了CRUD(创建、获取、更新、删除)、查询、排序和分页的相关操作。
-
Spring Data JPA
Spring Data JPA是较大的Spring Data系列的一部分,可轻松实现基于JPA的存储库。该模块处理对基于JPA的数据访问层的增强支持。它使构建使用数据访问技术的Spring支持的应用程序变得更加容易。
实现应用程序的数据访问层已经很长一段时间了。为了执行简单查询以及执行分页和审核,必须编写太多样板代码。Spring Data JPA旨在通过将工作量减少到实际需要的数量来显着改善数据访问层的实现。作为开发人员,您将编写包括自定义finder方法在内的存储库接口,Spring会自动提供实现
1)、统一的Repository接口
- Repository<T, ID extends Serializable>:统一接口
- RevisionRepository<T, ID extends Serializable, N extends Number & Comparable<N>>:基于乐观锁机制
- CrudRepository<T, ID extends Serializable>:基本CRUD操作
- PagingAndSortingRepository<T, ID extends Serializable>:基本CRUD及分页
2)、提供数据访问模板类 xxxTemplate
如:MongoTemplate、RedisTemplate等
3)、JPA与Spring Data
1.JpaRepository基本功能
编写接口继承JpaRepository既有crud及分页等基本功能
2.定义符合规范的方法命名
在接口中只需要声明符合规范的方法,即拥有对应的功能
3.@Query自定义查询,定制查询SQL
4.Specifications查询(Spring Data JPA支持JPA2.0的Criteria查询)
-
SpringBoot整合JPA
1)、添加Maven依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>
2)、编写Repository接口
public interface UserRepository extends JpaRepository<User,Integer> {
}
3)、实体和controller
/**
* @ClassName: User
* =================================================
* @Description: 用户实体对象
* --@Entity 告诉JPA这是一个实体类,数据库表的映射类
* --@Table 指定实体对应的数据库表,不设置默认是user
* --@Id 主键
* --@GeneratedValue 指定主键生产策略
* --@Column 指定列名,如果不设置字段名默认就是属性名
* =================================================
* CreateInfo:
* @Author: William.Wangmy
* @Email: wangmingyong2018@163.com
* @CreateDate: 2020/2/13 22:35
* @Version: V1.0
*/
@Entity
@Table(name="s_user")
public class User {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Integer id;
@Column(name = "user_name",length = 16)
private String userName;
@Column
private Integer age;
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public String getUserName() {
return userName;
}
public void setUserName(String userName) {
this.userName = userName;
}
public Integer getAge() {
return age;
}
public void setAge(Integer age) {
this.age = age;
}
}
@RestController
public class UserController {
@Autowired
private UserRepository userRepository;
@GetMapping("/user/{id}")
public User getUser(@PathVariable("id") Integer id){
return userRepository.findById(id).get();
}
@GetMapping("/user")
public User insertUser(User user){
return userRepository.save(user);
}
}