写在前面:从2018年底开始学习SpringBoot,也用SpringBoot写过一些项目。现在对学习Springboot的一些知识总结记录一下。如果你也在学习SpringBoot,可以关注我,一起学习,一起进步。
相关文章:
【Springboot系列】Springboot入门到项目实战
文章目录
-
- 搭建项目
-
- 1、新建SpringBoot项目
- 2、配置基本属性
- 编写代码
-
- 1、创建持久化类
- 2、定义数据访问层接口
- 3、定义业务层类
- 4、定义控制器类
- 测试应用
-
- 1、测试
- 2、源码下载
现在实际开发中开始使用SpringDataJpa,在实际开发中新建实体类时,有时候会出现几个实体类中有着相同的属性,比如一套学生管理系统中,teacher老师表和student学生表中都需要账号,密码,姓名等字段。这时就可以写一个公共的实体类把这些相同的字段存放进去,之后teacher和student类就可以直接继承公共的实体类。
搭建项目
1、新建SpringBoot项目
引入对应的依赖,完整pom.xml文件代码如下。
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.2.1.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.mcy.springdatajpa</groupId>
<artifactId>spring-data-jpa-entity</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>spring-data-jpa-entity</name>
<description>Demo project for Spring Boot</description>
<properties>
<java.version>1.8</java.version>
</properties>
<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>
<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>
</plugins>
</build>
</project>
2、配置基本属性
在src/main/resources下找到application.properties文件,在该配置文件中配置数据源和jpa相关的属性,需要在数据库中先新建一个jpa数据库。
#数据源信息配置
#数据库地址,jpa数据库名,需要在数据库中先建一个jpa数据库
spring.datasource.url=jdbc:mysql://localhost:3306/jpa?serverTimezone=GMT%2B8
#用户名
spring.datasource.username=root
#密码
spring.datasource.password=root
#链接数据库驱动
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
#指定数据库方言
spring.jpa.database-platform=org.hibernate.dialect.MySQL5InnoDBDialect
#配置在日志中显示SQL语句
spring.jpa.show-sql=true
#指定自动创建|更新|验证数据库表结构等配置,配置成updata
#表示如果数据库中存在持久化类对应的表就不创建,不存在就创建对应的表
spring.jpa.hibernate.ddl-auto=update
spring.jpa.hibernate.use-new-id-generator-mappings=false
编写代码
1、创建持久化类
在项目中新建4个包,分别为entity(放置持久化类)、controller(控制器)、repository(定义数据访问接口的包)、service(业务逻辑处理类)。
在entity包中创建一个持久化类SysUser.java作为公共的实体类。代码如下。
import javax.persistence.*;
/**
* 公共实体类
*/
@Entity
@Inheritance(strategy = InheritanceType.JOINED)
public class SysUser {
@Id
@GeneratedValue
protected Integer id;
protected String username;
protected String password;
protected String name;
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 String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
在entity包中创建一个持久化类Teacher.java教师表和Student.java学生类,之后继承公共的SysUser.java实体类。代码如下。
import javax.persistence.Entity;
/**
* 老师类,继承公共实体类SysUser
*/
@Entity
public class Teacher extends SysUser{
private String job;
public String getJob() {
return job;
}
public void setJob(String job) {
this.job = job;
}
}
Student.java类
import javax.persistence.Entity;
/**
* 学生类,继承公共实体类SysUser
*/
@Entity
public class Student extends SysUser {
private String banji;
public String getBanji() {
return banji;
}
public void setBanji(String banji) {
this.banji = banji;
}
}
数据库里会自动给我们建立三个表,sys_user,student,teacher。其中sys_user 表里会有四个字段,id,username,password,name; student表里会有两个字段,id,banji。teacher表里会有两个字段id,job。
2、定义数据访问层接口
在repository包下新建三个接口,代码如下。
UserRepository.java公共实体类接口
import com.mcy.springdatajpa.springdatajpaentity.entity.SysUser;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.stereotype.Repository;
@Repository
public interface UserRepository extends JpaRepository<SysUser, Integer> {
}
StudentRepository.java学生类接口
import com.mcy.springdatajpa.springdatajpaentity.entity.Student;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.stereotype.Repository;
@Repository
public interface StudentRepository extends JpaRepository<Student, Integer> {
}
TeacherRepository.java老师类接口
import com.mcy.springdatajpa.springdatajpaentity.entity.Teacher;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.stereotype.Repository;
@Repository
public interface TeacherRepository extends JpaRepository<Teacher, Integer> {
}
3、定义业务层类
在service包下新建一个三个类,包含查询和添加方法。代码如下。
UserService.java类
import org.springframework.stereotype.Service;
@Service
public class UserService {
}
StudentService.java类
import com.mcy.springdatajpa.springdatajpaentity.entity.Student;
import com.mcy.springdatajpa.springdatajpaentity.repository.StudentRepository;
import org.springframework.stereotype.Service;
import javax.annotation.Resource;
import java.util.List;
@Service
public class StudentService {
@Resource
private StudentRepository studentRepository;
public void save(Student student) {
studentRepository.save(student);
}
public List<Student> findAll() {
return studentRepository.findAll();
}
}
TeacherService.java类
import com.mcy.springdatajpa.springdatajpaentity.entity.Teacher;
import com.mcy.springdatajpa.springdatajpaentity.repository.TeacherRepository;
import org.springframework.stereotype.Service;
import javax.annotation.Resource;
import java.util.List;
@Service
public class TeacherService {
@Resource
private TeacherRepository teacherRepository;
public void save(Teacher teacher) {
teacherRepository.save(teacher);
}
public List<Teacher> findAll() {
return teacherRepository.findAll();
}
}
4、定义控制器类
在controller包下新建一个IndexController类,包含保存数据和查询数据方法。代码如下。
import com.mcy.springdatajpa.springdatajpaentity.entity.Student;
import com.mcy.springdatajpa.springdatajpaentity.entity.Teacher;
import com.mcy.springdatajpa.springdatajpaentity.service.StudentService;
import com.mcy.springdatajpa.springdatajpaentity.service.TeacherService;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import javax.annotation.Resource;
import java.util.List;
@RestController
@RequestMapping("/index")
public class IndexController {
@Resource
private StudentService studentService;
@Resource
private TeacherService teacherService;
@RequestMapping("/save")
public String save(){
Teacher t1=new Teacher();
t1.setName("张老师");
t1.setUsername("t01");
t1.setPassword("1111");
t1.setJob("班主任");
teacherService.save(t1);
Student s1=new Student();
s1.setName("李学生");
s1.setBanji("软件工程一班");
s1.setUsername("20170101");
s1.setPassword("2222");
studentService.save(s1);
return "数据保存成功";
}
@RequestMapping("/findStu")
public Object findStu(){
List<Student> stu = studentService.findAll();
return stu;
}
@RequestMapping("/findTeacher")
public Object findTeacher(){
List<Teacher> teachers = teacherService.findAll();
return teachers;
}
}
测试应用
1、测试
启动MySQL数据库,在数据库中创建名为jpa的数据库。
springboot项目启动后,数据库里会自动给我们建立三个表,sys_user,student,teacher。其中sys_user 表里会有四个字段,id,username,password,name; student表里会有两个字段,id,banji。teacher表里会有两个字段id,job。
测试添加数据,在浏览器中输入http://localhost:8080/index/save,数据保存成功后返回“数据保存成功”,提示信息。
数据库中会新增控制器中save方法对应的数据,如图。
sys_user表
student表
teacher表
分析一下,teacher,和student表中的id其实是外键,用来关联sys_user表的主键id的。
测试一下读取teacher和student中的所有数据,
读取student表中的数据,浏览器访问http://localhost:8080/index/findStu,返回结果如图。
读取teacher表中的数据,浏览器访问http://localhost:8080/index/findTeacher,返回结果如图。
2、源码下载
案例代码下载链接:https://github.com/machaoyin/spring-data-jpa-entity