Spring Boot 整合 Spring Data Jpa
一、Spring Data Jpa的简介
spring data:其实就是spring 提供的一个操作数据的框架。而spring data JPA 只是spring data 框架下的一个基于JPA标准操作数据的模块。
spring data jpa :基于JPA的标准对数据进行操作。简化操作持久层的代码,只需要编写接口就可以,不需要写sql语句,甚至可以不用自己手动创建数据库表。
二、添加依赖
1 <!--添加springdatajpa的依赖--> 2 <dependency> 3 <groupId>org.springframework.boot</groupId> 4 <artifactId>spring-boot-starter-data-jpa</artifactId> 5 </dependency>
三、在项目中添加application.properties(或者application.yml)配置文件,添加数据源配置以及jpa的配置
以下两种任意一种都可以,表达的意思是一样的
a、application.properties配置文件
#DB Configuration
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
spring.datasource.url=jdbc:mysql://127.0.0.1:3306/springboot
spring.datasource.username=root
spring.datasource.password=ROOT
#JPA Configuration
spring.jpa.database=MySQL
spring.jpa.show-sql=true
spring.jpa.generate-ddl=true
b、application.yml配置文件
1 spring: 2 datasource: 3 driver-class-name: com.mysql.jdbc.Driver 4 url: jdbc:mysql://127.0.0.1:3306/springboot 5 username: root 6 password: ROOT 7 8 jpa: 9 database: mysql 10 show-sql: true 11 generate-ddl: true
四、添加实体类
注意
@Entity:标识这个实体类是一个JPA实体,告诉JPA在程序运行的时候记得生成这个实体类所对应的表~
@Table(name="自定义的表名"):自定义设置这个实体类在数据库所对应的表名!
@Id:表明哪一个属性对应表中的主键
@GeneratedValue(strategy = GenerationType.IDENTITY):主键自增长,设置主键的生成策略,这种方式依赖于具体的数据库,如果数据库不支持自增主键,那么这个类型是没法用的。
@Column(name = "自定义字段名",length = "自定义长度",nullable = "是否可以空",unique = "是否唯一",columnDefinition = "自定义该字段的类型和长度")
表示对这个变量所对应的字段名进行一些个性化的设置,例如字段的名字,字段的长度,是否为空和是否唯一等等设置。
1 package com.offcn.entity; 2 3 import javax.persistence.*; 4 5 @Entity 6 @Table(name = "user")//创建表 7 public class User { 8 @Id//标识主键 9 @GeneratedValue(strategy = GenerationType.IDENTITY)//主键自增长 10 private Integer id; 11 private String username; 12 private Integer age; 13 14 public Integer getId() { 15 return id; 16 } 17 18 public void setId(Integer id) { 19 this.id = id; 20 } 21 22 public String getUsername() { 23 return username; 24 } 25 26 public void setUsername(String username) { 27 this.username = username; 28 } 29 30 public Integer getAge() { 31 return age; 32 } 33 34 public void setAge(Integer age) { 35 this.age = age; 36 } 37 38 @Override 39 public String toString() { 40 return "User{" + 41 "id=" + id + 42 ", username='" + username + '\'' + 43 ", age=" + age + 44 '}'; 45 } 46 }
五、dao层添加接口
1 package com.offcn.dao; 2 3 import com.offcn.entity.User; 4 import org.springframework.data.jpa.repository.JpaRepository; 5 6 public interface UserDao extends JpaRepository<User,Integer> { 7 }

六、Controller层测试代码
package com.offcn.controller; import com.offcn.dao.UserDao; import com.offcn.entity.User; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; import java.util.Optional; @RestController @RequestMapping("/user") public class UserController { @Autowired private UserDao userDao; //添加 @RequestMapping("/saveInfo") public String saveInfo(){ User user = new User(); user.setAge(18); user.setUsername("小明"); userDao.save(user); return "success"; } //查询 @GetMapping("/getUsersById") public User getUserById(){ User user = userDao.getOne(1); return user; } }

浙公网安备 33010602011771号