Contents [hide ]
One to Many Mapping
One To Many mapping to represent one to many relationships between tables. A one to many relationships occurs between tables when one record from a table can correspond to many records from another table.
For example, In a department, many employees work. So one record in the Department table will correspond to many records in the Employee table.
data:image/s3,"s3://crabby-images/02ece/02ece0c5a5651de661aed4b50aca23cccf1c7f3b" alt="ONE TO MANY MAPPING ONE-TO-MANY-MAPPING"
Tools and Technologies Used:
1. Java 8
2. MySQL 8
3. Eclipse IDE
4. mysql-connector-java-8.0.23.jar
5. Hibernate 5.5.7.Final
6. Maven 3.6.1
Maven Project for One to Many Mapping
We need to follow below steps:
Step 1: Click on File --> New --> Maven Project.
data:image/s3,"s3://crabby-images/685df/685df1c9c2731e8aef424bdac138960f86c1eeab" alt="HIBERNATE ONE TO MANY MAPPING CREATE MAVEN PROJECT HIBERNATE-ONE-TO-MANY-MAPPING-CREATE-MAVEN-PROJECT"
Step 2: Check Checkbox Create a simple project (skip archetype selection). Click on Next button.
data:image/s3,"s3://crabby-images/4eb16/4eb1616a1d7d7f6a8dbddd3a03b042203825066f" alt="HIBERNATE ONE TO MANY MAPPING CREATE MAVEN PROJECT HIBERNATE-ONE-TO-MANY-MAPPING-CREATE-MAVEN-PROJECT"
Step 3: Enter Group Id, Artifact Id, Version, Packaging, Name, Description details and click on Finish button.
data:image/s3,"s3://crabby-images/f0926/f092662a2391adb853abe74e2d12a44dd6c4c1dd" alt="HIBERNATE ONE TO MANY MAPPING CREATE MAVEN PROJECT HIBERNATE-ONE-TO-MANY-MAPPING-CREATE-MAVEN-PROJECT"
Update pom.xml file.
Open pom.xml file and paste below pom.xml file code.
4.0.0 com.hareeshsoni.blog.hibernate.mapping HibernateOneToManyExample 0.0.1-SNAPSHOT HibernateOneToManyExample Hibernate One To Many Example org.hibernate hibernate-core 5.5.7.Final mysql mysql-connector-java 8.0.23 org.apache.maven.plugins maven-compiler-plugin 3.6.1 1.8 1.8
Update Maven Project
Step 1: Right-click on project HibernateOneToManyExample --> Maven --> Update Project…
data:image/s3,"s3://crabby-images/a7760/a7760384967f24a606a025bbf8fb05c456690c0b" alt="HIBERNATE ONE TO MANY MAPPING UPDATE MAVEN PROJECT HIBERNATE-ONE-TO-MANY-MAPPING-UPDATE-MAVEN-PROJECT"
Step 2: Check Checkbox Force Update of Snapshots/Releases. Click on OK Button.
data:image/s3,"s3://crabby-images/bf761/bf761c3cb19848fabbd37b533ace4021dde8ddea" alt="HIBERNATE ONE TO MANY MAPPING UPDATE MAVEN PROJECT HIBERNATE-ONE-TO-MANY-MAPPING-UPDATE-MAVEN-PROJECT"
We have used the below JPA Annotations:
@Entity: @Entity annotation specifies that the class is an entity.
@Table: @Table annotation specifies the primary table for the annotated entity.
@Id: @Id annotation marks the particular field as the primary key of the Entity.
@GeneratedValue: This annotation is used to specify how the primary key should be generated.
@Column: This annotation maps the corresponding fields to their respective columns in the database table.
@JoinColumn: This annotation defines the foreign key. It is the column that associates the two tables.
@OneToMany: This annotation is used to create one to many relationship between Department and Employee entities.
@ManyToOne: This annotation is used to create many to one relationship between Employee and Department entities.
package com.hareeshsoni.blog.hibernate.mapping.model; import java.util.Set; import javax.persistence.CascadeType; import javax.persistence.Column; import javax.persistence.Entity; import javax.persistence.GeneratedValue; import javax.persistence.GenerationType; import javax.persistence.Id; import javax.persistence.OneToMany; import javax.persistence.Table; @Entity @Table(name = "department") public class Department { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) @Column(name = "department_id") private int departmentId; @Column(name = "department_name") private String departmentName; @OneToMany(mappedBy = "department", cascade = CascadeType.ALL) private Setemployee; public Department() { } public Department(String departmentName) { this.departmentName = departmentName; } public int getDepartmentId() { return departmentId; } public void setDepartmentId(int departmentId) { this.departmentId = departmentId; } public String getDepartmentName() { return departmentName; } public void setDepartmentName(String departmentName) { this.departmentName = departmentName; } public Set getEmployee() { return employee; } public void setEmployee(Set employee) { this.employee = employee; } }
package com.hareeshsoni.blog.hibernate.mapping.model; import javax.persistence.CascadeType; import javax.persistence.Column; import javax.persistence.Entity; import javax.persistence.GeneratedValue; import javax.persistence.GenerationType; import javax.persistence.Id; import javax.persistence.JoinColumn; import javax.persistence.ManyToOne; import javax.persistence.Table; @Entity @Table(name = "employee") public class Employee { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) @Column(name = "employee_id") private int employeeId; @Column(name = "employee_name") private String employeeName; @ManyToOne(cascade = CascadeType.ALL) @JoinColumn(name = "department_id") private Department department; public Employee() { } public Employee(String employeeName) { this.employeeName = employeeName; } public int getEmployeeId() { return employeeId; } public void setEmployeeId(int employeeId) { this.employeeId = employeeId; } public String getEmployeeName() { return employeeName; } public void setEmployeeName(String employeeName) { this.employeeName = employeeName; } public Department getDepartment() { return department; } public void setDepartment(Department department) { this.department = department; } }
package com.hareeshsoni.blog.hibernate.mapping.util; import org.hibernate.SessionFactory; import org.hibernate.cfg.Configuration; public class HibernateUtil { private static SessionFactory sessionFactory; private static SessionFactory buildSessionFactory() { Configuration configuration = new Configuration(); configuration.configure("hibernate.cfg.xml"); System.out.println("Hibernate configuration file loaded"); SessionFactory sessionFactory = configuration.buildSessionFactory(); return sessionFactory; } public static SessionFactory getSessionFactory() { if(sessionFactory == null) sessionFactory = buildSessionFactory(); return sessionFactory; } }
In hibernate.cfg.xml file provide correct username and password.
Create database name "one_to_many_mapping" inside mysql database.
com.mysql.cj.jdbc.Driver jdbc:mysql://localhost:3306/one_to_many_mapping root ######## org.hibernate.dialect.MySQL5Dialect true update
package com.hareeshsoni.blog.hibernate.mapping; import org.hibernate.Session; import org.hibernate.SessionFactory; import com.hareeshsoni.blog.hibernate.mapping.model.Department; import com.hareeshsoni.blog.hibernate.mapping.model.Employee; import com.hareeshsoni.blog.hibernate.mapping.util.HibernateUtil; public class MainApp { public static void main(String[] args) { SessionFactory sessionFactory = HibernateUtil.getSessionFactory(); Session session = sessionFactory.openSession(); session.beginTransaction(); Department department = new Department("Human Resource"); Employee employee1 = new Employee("Mohan"); employee1.setDepartment(department); session.save(employee1); Employee employee2 = new Employee("Rohan"); employee2.setDepartment(department); session.save(employee2); session.getTransaction().commit(); session.close(); sessionFactory.close(); } }
Now run MainApp.java
data:image/s3,"s3://crabby-images/566cd/566cdcbd31112c4b51ad9b839533a98d0b5c1827" alt="ONE TO MANY MAPPING RUN MAIN APP ONE-TO-MANY-MAPPING-RUN-MAIN-APP"
Output
data:image/s3,"s3://crabby-images/093e1/093e1d172fd04ce13b8255aa716a08224b432192" alt="ONE TO MANY MAPPING OUTPUT ONE-TO-MANY-MAPPING-OUTPUT"
Database tables:
Department Table
data:image/s3,"s3://crabby-images/90df6/90df6e454e86c390b60fe96fd52fcc8f74899e67" alt="DEPARTMENT TABLE DEPARTMENT-TABLE"
Employee Table
data:image/s3,"s3://crabby-images/04bbb/04bbb9031c817509f13ad5dffb8164cc6fc1fab3" alt="EMPLOYEE TABLE EMPLOYEE-TABLE"