[Java Spring Data] JPA Example with unit test
domain/Course.java
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 | package com.example.university.domain; import javax.persistence.*; /** * JPA Entity for a Course offered at the University. * <p> * Created by maryellenbowman. */ @Entity @Table (name = "COURSE" ) public class Course { @Id @GeneratedValue private Integer id; @Column private String name; @ManyToOne @JoinColumn private Department department; public Course(String name, Department department) { this .name = name; this .department = department; } protected Course() { } public Integer getId() { return id; } public String getName() { return name; } public void setDepartment(Department department) { this .department = department; } @Override public String toString() { return "Course{" + "id=" + id + ", name='" + name + '\ '' + ", department=" + department.getName() + '}' ; } } |
domain/Department.java
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 | package com.example.university.domain; import javax.persistence.*; import java.util.ArrayList; import java.util.List; /** * JPA Entity for a Department of study at the University. * <p> * Created by maryellenbowman */ @Entity @Table (name = "Department" ) public class Department { @Id @GeneratedValue private Integer id; @Column private String name; @OneToMany (mappedBy = "department" , fetch = FetchType.EAGER, cascade = CascadeType.ALL) private List<Course> courses = new ArrayList<>(); public Department(String name) { this .name = name; } protected Department() { } public Integer getId() { return id; } public String getName() { return name; } public void addCourse(Course course) { courses.add(course); } @Override public String toString() { return "Department{" + "id=" + id + ", name='" + name + '\ '' + ", courses=" + courses + '}' ; } } |
domain/Person.java
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 | package com.example.university.domain; import javax.persistence.Column; import javax.persistence.Embeddable; /** * Person encapsulates an individual's first and last name. * <p> * Created by maryellenbowman */ @Embeddable public class Person { @Column private String firstName; @Column private String lastName; public Person(String firstName, String lastName) { this .firstName = firstName; this .lastName = lastName; } protected Person() { } public String getFirstName() { return firstName; } public String getLastName() { return lastName; } @Override public String toString() { return " firstName='" + firstName + '\ '' + ", lastname='" + lastName + "\' " ; } } |
domain/Student.java
package com.example.university.domain; import javax.persistence.*; import java.util.ArrayList; import java.util.List; /** * JPA Entity representing a student at the University. * <p> * Created by maryellenbowman */ @Entity @Table(name = "STUDENT") public class Student { @Id @GeneratedValue private Integer studentId; @Column private boolean fullTime; @Column private Integer age; @Embedded private Person attendee; @OneToMany private List<Course> courses = new ArrayList<>(); public Student(Person attendee, boolean fullTime, Integer age) { this.attendee = attendee; this.fullTime = fullTime; this.age = age; courses = new ArrayList<>(); } protected Student() { } public Integer getStudentId() { return studentId; } public Person getAttendee() { return attendee; } public void setAge(Integer age) { this.age = age; } public boolean isFullTime() { return fullTime; } public Integer getAge() { return age; } public List<Course> getCourses() { return courses; } @Override public String toString() { return "Student{" + "studentId=" + studentId + ", " + attendee + ", fullTime=" + fullTime + ", age=" + age + "}\n"; } }
repo/StudentRepository.java
package com.example.university.repo; import com.example.university.domain.Student; import org.springframework.data.repository.CrudRepository; /** * DataSource Management for the Students at the University. * * Created by maryellenbowman */ public interface StudentRepository extends CrudRepository<Student, Integer>{ }
test:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 | package com.example.university; import com.example.university.domain.Person; import com.example.university.domain.Student; import com.example.university.repo.StudentRepository; import org.junit.Test; import org.junit.runner.RunWith; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.boot.test.context.SpringBootTest; import org.springframework.test.context.junit4.SpringRunner; /** * Demonstrate Creation, Reading, Updating, and Deletion of Students with StudentRepository * <p> * Created by maryellenbowman */ @RunWith (SpringRunner. class ) @SpringBootTest public class CrudRepositoryDemo { @Autowired StudentRepository studentRepository; /** * Exercise CrudRepository methods. */ @Test public void simpleStudentCrudExample() { boolean fullTime = true ; studentRepository.save( new Student( new Person( "jane" , "doe" ), fullTime, 20 )); studentRepository.save( new Student( new Person( "john" , "doe" ), fullTime, 22 )); studentRepository.save( new Student( new Person( "mike" , "smith" ), fullTime, 18 )); studentRepository.save( new Student( new Person( "ally" , "kim" ), !fullTime, 19 )); System.out.println( "\n*************Original Students*************" ); studentRepository.findAll().forEach(System.out::println); //age up the students studentRepository.findAll().forEach(student -> { student.setAge(student.getAge() + 1 ); studentRepository.save(student); }); System.out.println( "\n*************Students a year older*************" ); studentRepository.findAll().forEach(System.out::println); studentRepository.deleteAll(); System.out.println( "\n*************Students removed*************" ); studentRepository.findAll().forEach(System.out::println); } } |
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
2019-12-17 [Algorithm] 202. Happy Number
2019-12-17 [Javascript] Creating an Iterator from an Array
2018-12-17 [Algorithm] Write a Depth First Search Algorithm for Graphs in JavaScript
2018-12-17 [Algorithms] Refactor a Loop in JavaScript to Use Recursion
2018-12-17 [Bash] Understand and Use Functions in Bash
2018-12-17 [Javascript] Await a JavaScript Promise in an async Function with the await Operator
2017-12-17 [Python] Array Attributes of Numpy lib