Tài liệu Giáo trình Lập trình Java 4 - Bài 7: Bài thực hành số 7 - Trường Cao đẳng FPT: SOF301 – Ngôn ngữ lập trình Java 4 Lab 7
1
Bài thực hành số 7
Mục tiêu
Hiểu cách sử dụng các thành phần cơ bản trong ngôn ngữ Hibernate
Hibernate Mapping: one to one
Hibernate Mapping: Many to one
Hibernate Mapping: one to many
Hibernate Mapping: many to many
SOF301 – Ngôn ngữ lập trình Java 4 Lab 7
2
Sử dụng cơ sở dữ liệu tài nguyên simpleHr
Bài 1 Tạo Project và khai báo thư viện
Tạo thư mục Libs trong project và add những file sau
Nhấn phải chuột vào Project chọn Properties
Add hết tất cả các thư viện có trong thư mục libs:
SOF301 – Ngôn ngữ lập trình Java 4 Lab 7
3
SOF301 – Ngôn ngữ lập trình Java 4 Lab 7
4
Bài 2 Tạo Class Entity
Chúng ta tạo các class Entity. Mỗi Entity sẽ mô tả một bảng trong DB.
1. Department - Phòng ban
2. Employee - Nhân viên
3. SalaryGrade - Bậc lương
4. Timekeeper - Máy chấm công, giờ ra vào của nhân viên.
• Department.java
?
1
2
3
4
5
6
package org.Fpoly.tutorial.hibernate.entiti...
15 trang |
Chia sẻ: quangot475 | Lượt xem: 1180 | Lượt tải: 1
Bạn đang xem nội dung tài liệu Giáo trình Lập trình Java 4 - Bài 7: Bài thực hành số 7 - Trường Cao đẳng FPT, để tải tài liệu về máy bạn click vào nút DOWNLOAD ở trên
SOF301 – Ngôn ngữ lập trình Java 4 Lab 7
1
Bài thực hành số 7
Mục tiêu
Hiểu cách sử dụng các thành phần cơ bản trong ngôn ngữ Hibernate
Hibernate Mapping: one to one
Hibernate Mapping: Many to one
Hibernate Mapping: one to many
Hibernate Mapping: many to many
SOF301 – Ngôn ngữ lập trình Java 4 Lab 7
2
Sử dụng cơ sở dữ liệu tài nguyên simpleHr
Bài 1 Tạo Project và khai báo thư viện
Tạo thư mục Libs trong project và add những file sau
Nhấn phải chuột vào Project chọn Properties
Add hết tất cả các thư viện có trong thư mục libs:
SOF301 – Ngôn ngữ lập trình Java 4 Lab 7
3
SOF301 – Ngôn ngữ lập trình Java 4 Lab 7
4
Bài 2 Tạo Class Entity
Chúng ta tạo các class Entity. Mỗi Entity sẽ mô tả một bảng trong DB.
1. Department - Phòng ban
2. Employee - Nhân viên
3. SalaryGrade - Bậc lương
4. Timekeeper - Máy chấm công, giờ ra vào của nhân viên.
• Department.java
?
1
2
3
4
5
6
package org.Fpoly.tutorial.hibernate.entities;
import java.util.HashSet;
import java.util.Set;
import javax.persistence.Column;
SOF301 – Ngôn ngữ lập trình Java 4 Lab 7
5
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
import javax.persistence.Entity;
import javax.persistence.FetchType;
import javax.persistence.Id;
import javax.persistence.OneToMany;
import javax.persistence.Table;
import javax.persistence.UniqueConstraint;
@Entity
@Table(name = "DEPARTMENT",
uniqueConstraints = { @UniqueConstraint(columnNames = { "DEPT_NO"
}) })
public class Department {
private Integer deptId;
private String deptNo;
private String deptName;
private String location;
private Set employees = new HashSet(0);
public Department() {
}
public Department(Integer deptId, String deptName, String location) {
this.deptId = deptId;
this.deptNo = "D" + this.deptId;
this.deptName = deptName;
this.location = location;
}
@Id
@Column(name = "DEPT_ID")
public Integer getDeptId() {
return deptId;
}
public void setDeptId(Integer deptId) {
SOF301 – Ngôn ngữ lập trình Java 4 Lab 7
6
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
this.deptId = deptId;
}
@Column(name = "DEPT_NO", length = 20, nullable = false)
public String getDeptNo() {
return deptNo;
}
public void setDeptNo(String deptNo) {
this.deptNo = deptNo;
}
@Column(name = "DEPT_NAME", nullable = false)
public String getDeptName() {
return deptName;
}
public void setDeptName(String deptName) {
this.deptName = deptName;
}
@Column(name = "LOCATION")
public String getLocation() {
return location;
}
public void setLocation(String location) {
this.location = location;
}
@OneToMany(fetch = FetchType.LAZY, mappedBy = "department")
public Set getEmployees() {
return employees;
}
public void setEmployees(Set employees) {
this.employees = employees;
SOF301 – Ngôn ngữ lập trình Java 4 Lab 7
7
81 }
}
• Employee.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
package org.Fpoly.tutorial.hibernate.entities;
import java.util.Date;
import java.util.HashSet;
import java.util.Set;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.FetchType;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.Lob;
import javax.persistence.ManyToOne;
import javax.persistence.OneToMany;
import javax.persistence.Table;
import javax.persistence.Temporal;
import javax.persistence.TemporalType;
import javax.persistence.UniqueConstraint;
@Entity
@Table(name = "EMPLOYEE",
uniqueConstraints = { @UniqueConstraint(columnNames = {
"EMP_NO" }) })
public class Employee {
private Long empId;
private String empNo;
private String empName;
private String job;
private Employee manager;
SOF301 – Ngôn ngữ lập trình Java 4 Lab 7
8
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
56
57
58
59
60
61
62
63
64
65
66
67
private Date hideDate;
private Float salary;
private byte[] image;
private Department department;
private Set employees = new HashSet(0);
public Employee() {
}
public Employee(Long empId, String empName, String job, Employee
manager,
Date hideDate, Float salary, Float comm, Department
department) {
this.empId = empId;
this.empNo = "E" + this.empId;
this.empName = empName;
this.job = job;
this.manager = manager;
this.hideDate = hideDate;
this.salary = salary;
this.department = department;
}
@Id
@Column(name = "EMP_ID")
public Long getEmpId() {
return empId;
}
public void setEmpId(Long empId) {
this.empId = empId;
}
@Column(name = "EMP_NO", length = 20, nullable = false)
public String getEmpNo() {
return empNo;
SOF301 – Ngôn ngữ lập trình Java 4 Lab 7
9
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
}
public void setEmpNo(String empNo) {
this.empNo = empNo;
}
@Column(name = "EMP_NAME", length = 50, nullable = false)
public String getEmpName() {
return empName;
}
public void setEmpName(String empName) {
this.empName = empName;
}
@Column(name = "JOB", length = 30, nullable = false)
public String getJob() {
return job;
}
public void setJob(String job) {
this.job = job;
}
@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name = "MNG_ID")
public Employee getManager() {
return manager;
}
public void setManager(Employee manager) {
this.manager = manager;
}
@Column(name = "HIRE_DATE", nullable = false)
@Temporal(TemporalType.DATE)
public Date getHideDate() {
SOF301 – Ngôn ngữ lập trình Java 4 Lab 7
10
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
return hideDate;
}
public void setHideDate(Date hideDate) {
this.hideDate = hideDate;
}
@Column(name = "SALARY", nullable = false)
public Float getSalary() {
return salary;
}
public void setSalary(Float salary) {
this.salary = salary;
}
@Column(name = "IMAGE", length = 1111111, nullable = true)
@Lob
public byte[] getImage() {
return image;
}
public void setImage(byte[] image) {
this.image = image;
}
@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name = "DEPT_ID", nullable = false)
public Department getDepartment() {
return department;
}
public void setDepartment(Department department) {
this.department = department;
}
@OneToMany(fetch = FetchType.LAZY, mappedBy = "empId")
SOF301 – Ngôn ngữ lập trình Java 4 Lab 7
11
142
143
144
145
146
147
public Set getEmployees() {
return employees;
}
public void setEmployees(Set employees) {
this.employees = employees;
}
}
• SalaryGrade.java
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
package org.Fpoly.tutorial.hibernate.entities;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.Id;
import javax.persistence.Table;
@Entity
@Table(name = "SALARY_GRADE")
public class SalaryGrade {
private Integer grade;
private Float lowSalary;
private Float highSalary;
public SalaryGrade() {
}
public SalaryGrade(Integer grade, Float lowSalary, Float
highSalary) {
this.grade = grade;
this.lowSalary = lowSalary;
this.highSalary = highSalary;
}
SOF301 – Ngôn ngữ lập trình Java 4 Lab 7
12
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
@Id
@Column(name = "GRADE")
public Integer getGrade() {
return grade;
}
public void setGrade(Integer grade) {
this.grade = grade;
}
@Column(name = "LOW_SALARY", nullable = false)
public Float getLowSalary() {
return lowSalary;
}
public void setLowSalary(Float lowSalary) {
this.lowSalary = lowSalary;
}
@Column(name = "HIGH_SALARY", nullable = false)
public Float getHighSalary() {
return highSalary;
}
public void setHighSalary(Float highSalary) {
this.highSalary = highSalary;
}
}
• Timekeeper.java
?
1
2
3
package org.Fpoly.tutorial.hibernate.entities;
import java.util.Date;
SOF301 – Ngôn ngữ lập trình Java 4 Lab 7
13
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
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.FetchType;
import javax.persistence.GeneratedValue;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.ManyToOne;
import javax.persistence.Table;
import javax.persistence.Temporal;
import javax.persistence.TemporalType;
import org.hibernate.annotations.GenericGenerator;
@Entity
@Table(name = "TIMEKEEPER")
public class Timekeeper {
public static final char IN = 'I';
public static final char OUT = 'O';
private String timekeeperId;
private Date dateTime;
private Employee employee;
// 'I' or 'O'
private char inOut;
@Id
@GeneratedValue(generator = "uuid")
@GenericGenerator(name = "uuid", strategy = "uuid2")
@Column(name = "Timekeeper_Id", length = 36)
public String getTimekeeperId() {
return timekeeperId;
}
SOF301 – Ngôn ngữ lập trình Java 4 Lab 7
14
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
public void setTimekeeperId(String timekeeperId) {
this.timekeeperId = timekeeperId;
}
@Column(name = "Date_Time", nullable = false)
@Temporal(TemporalType.TIMESTAMP)
public Date getDateTime() {
return dateTime;
}
public void setDateTime(Date dateTime) {
this.dateTime = dateTime;
}
@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name = "EMP_ID", nullable = false)
public Employee getEmployee() {
return employee;
}
public void setEmployee(Employee employee) {
this.employee = employee;
}
@Column(name = "In_Out", nullable = false, length = 1)
public char getInOut() {
return inOut;
}
public void setInOut(char inOut) {
this.inOut = inOut;
}
}
SOF301 – Ngôn ngữ lập trình Java 4 Lab 7
15
Bài 3
Giảng viên giao thêm bài cho sinh viên.
Yêu cầu nộp bài
Cuối giờ thực hành, sinh viên tạo thư mục theo tên _Lab1, chứa tất cả sản phẩm
của những bài lab trên, nén lại thành file zip và upload lên mục nộp bài tương ứng trên LMS.
Đánh giá bài lab
STT Bài số Điểm
1 Bài 1
2 Bài 2
3 Bài 3
Các file đính kèm theo tài liệu này:
- sof301_lab_7_7355_2154497.pdf