JPA-엔티티 관리자
이 장에서는 JPA를 사용한 간단한 예제를 설명합니다. 직원 관리를 예로 들어 보겠습니다. 이는 직원 관리가 직원을 만들고, 업데이트하고, 찾고, 삭제하고 있음을 의미합니다. 위에서 언급했듯이 우리는 데이터베이스 작업을 위해 MySQL 데이터베이스를 사용하고 있습니다.
이 예제의 주요 모듈은 다음과 같습니다.
Model or POJO
Employee.java
Persistence
Persistence.xml
Service
CreatingEmployee.java
UpdatingEmployee.java
FindingEmployee.java
DeletingEmployee.java
Eclipselink를 사용한 JPA 설치에서 사용한 패키지 계층 구조를 살펴 보겠습니다. 이 예제의 계층 구조를 따르십시오.
엔티티 생성
엔티티는 빈 또는 모델 일뿐입니다.이 예제에서는 Employee 엔티티로. eid, ename, salary, 과 deg이 엔티티의 속성입니다. 여기에는 해당 속성의 기본 생성자, setter 및 getter 메서드가 포함되어 있습니다.
위에 표시된 계층 구조에서 ‘com.tutorialspoint.eclipselink.entity’, 아래에 ‘src’(소스) 패키지. 이름이 지정된 클래스 만들기Employee.java 다음과 같이 주어진 패키지에서 :
package com.tutorialspoint.eclipselink.entity;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.Table;
@Entity
@Table
public class Employee {
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
private int eid;
private String ename;
private double salary;
private String deg;
public Employee(int eid, String ename, double salary, String deg) {
super( );
this.eid = eid;
this.ename = ename;
this.salary = salary;
this.deg = deg;
}
public Employee( ) {
super();
}
public int getEid( ) {
return eid;
}
public void setEid(int eid) {
this.eid = eid;
}
public String getEname( ) {
return ename;
}
public void setEname(String ename) {
this.ename = ename;
}
public double getSalary( ) {
return salary;
}
public void setSalary(double salary) {
this.salary = salary;
}
public String getDeg( ) {
return deg;
}
public void setDeg(String deg) {
this.deg = deg;
}
@Override
public String toString() {
return "Employee [eid=" + eid + ", ename=" + ename + ", salary=" + salary + ", deg=" + deg + "]";
}
}
위의 코드에서는 @Entity 주석을 사용하여이 POJO 클래스를 엔티티로 만들었습니다.
다음 모듈로 이동하기 전에 관계형 엔티티에 대한 데이터베이스를 생성해야합니다. persistence.xml파일. MySQL 워크 벤치를 열고 다음과 같이 query를 입력합니다.
create database jpadb
use jpadb
Persistence.xml
이 모듈은 JPA 개념에서 중요한 역할을합니다. 이 xml 파일에서 데이터베이스를 등록하고 엔티티 클래스를 지정합니다.
위에 표시된 패키지 계층에서 JPA 콘텐츠 패키지 아래의 persistence.xml은 다음과 같습니다.
<?xml version="1.0" encoding="UTF-8"?>
<persistence version="2.0" xmlns="http://java.sun.com/xml/ns/persistence"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/persistence
http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd">
<persistence-unit name="Eclipselink_JPA" transaction-type="RESOURCE_LOCAL">
<class>com.tutorialspoint.eclipselink.entity.Employee</class>
<properties>
<property name="javax.persistence.jdbc.url" value="jdbc:mysql://localhost:3306/jpadb"/>
<property name="javax.persistence.jdbc.user" value="root"/>
<property name="javax.persistence.jdbc.password" value="root"/>
<property name="javax.persistence.jdbc.driver" value="com.mysql.jdbc.Driver"/>
<property name="eclipselink.logging.level" value="FINE"/>
<property name="eclipselink.ddl-generation" value="create-tables"/>
</properties>
</persistence-unit>
</persistence>
위의 xml에서 <persistence-unit> 태그는 JPA 지속성을위한 특정 이름으로 정의됩니다. <class> 태그는 패키지 이름으로 엔티티 클래스를 정의합니다. <properties> 태그는 모든 속성을 정의하고 <property> 태그는 데이터베이스 등록, URL 사양, 사용자 이름 및 암호와 같은 각 속성을 정의합니다. 이것은 Eclipselink 속성입니다. 이 파일은 데이터베이스를 구성합니다.
지속성 작업
지속성 작업은 데이터베이스에 대해 사용되며 load 과 store작업. 비즈니스 구성 요소에서 모든 지속성 작업은 서비스 클래스에 속합니다.
위에 표시된 패키지 계층 구조에서 ‘com.tutorialspoint.eclipselink.service’, 아래에 ‘src’(소스) 패키지. CreateEmloyee.java, UpdateEmployee.java, FindEmployee.java 및 DeleteEmployee.java로 이름 지정된 모든 서비스 클래스. 다음과 같이 주어진 패키지에 포함됩니다.
직원 생성
다음과 같은 Employee 클래스 만들기 CreateEmployee.java 다음과 같이 :
package com.tutorialspoint.eclipselink.service;
import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import javax.persistence.Persistence;
import com.tutorialspoint.eclipselink.entity.Employee;
public class CreateEmployee {
public static void main( String[ ] args ) {
EntityManagerFactory emfactory = Persistence.createEntityManagerFactory( "Eclipselink_JPA" );
EntityManager entitymanager = emfactory.createEntityManager( );
entitymanager.getTransaction( ).begin( );
Employee employee = new Employee( );
employee.setEid( 1201 );
employee.setEname( "Gopal" );
employee.setSalary( 40000 );
employee.setDeg( "Technical Manager" );
entitymanager.persist( employee );
entitymanager.getTransaction( ).commit( );
entitymanager.close( );
emfactory.close( );
}
}
위의 코드에서 createEntityManagerFactory ()persistence.xml 파일에서 persistence-unit에 제공하는 것과 동일한 고유 이름을 제공하여 지속성 단위를 생성합니다. entitymanagerfactory 객체는 다음을 사용하여 entitymanger 인스턴스를 생성합니다.createEntityManager ()방법. entitymanager 객체는 트랜잭션 관리를위한 entitytransaction 인스턴스를 생성합니다. entitymanager 객체를 사용하여 엔티티를 데이터베이스에 유지할 수 있습니다.
위의 프로그램을 컴파일하고 실행하면 Eclipse IDE의 콘솔 패널에있는 eclipselink 라이브러리에서 알림을받습니다.
결과를 보려면 MySQL 워크 벤치를 열고 다음 쿼리를 입력하십시오.
use jpadb
select * from employee
영향을받는 데이터베이스 테이블 이름 employee 다음과 같은 표 형식으로 표시됩니다.
Eid | Ename | 봉급 | 도 |
---|---|---|---|
1201 | 고팔 | 40000 | 기술 관리자 |
직원 업데이트
직원을 업데이트하려면 레코드 양식 데이터베이스를 가져 와서 변경 한 다음 마지막으로 커밋해야합니다. 명명 된 클래스UpdateEmployee.java 다음과 같이 표시됩니다.
package com.tutorialspoint.eclipselink.service;
import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import javax.persistence.Persistence;
import com.tutorialspoint.eclipselink.entity.Employee;
public class UpdateEmployee {
public static void main( String[ ] args ) {
EntityManagerFactory emfactory = Persistence.createEntityManagerFactory( "Eclipselink_JPA" );
EntityManager entitymanager = emfactory.createEntityManager( );
entitymanager.getTransaction( ).begin( );
Employee employee = entitymanager.find( Employee.class, 1201 );
//before update
System.out.println( employee );
employee.setSalary( 46000 );
entitymanager.getTransaction( ).commit( );
//after update
System.out.println( employee );
entitymanager.close();
emfactory.close();
}
}
위 프로그램을 컴파일하고 실행하면 Eclipse IDE의 콘솔 패널에있는 Eclipselink 라이브러리에서 알림을받습니다.
결과를 보려면 MySQL 워크 벤치를 열고 다음 쿼리를 입력하십시오.
use jpadb
select * from employee
영향을받는 데이터베이스 테이블 이름 employee 다음과 같은 표 형식으로 표시됩니다.
Eid | Ename | 봉급 | 도 |
---|---|---|---|
1201 | 고팔 | 46000 | 기술 관리자 |
직원 급여 1201이 46000으로 업데이트되었습니다.
직원 찾기
직원을 찾기 위해 데이터베이스에서 레코드를 가져와 표시합니다. 이 작업에서 EntityTransaction은 레코드를 검색하는 동안 적용되지 않는 트랜잭션이 포함되지 않습니다.
명명 된 클래스 FindEmployee.java 다음과 같이.
package com.tutorialspoint.eclipselink.service;
import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import javax.persistence.Persistence;
import com.tutorialspoint.eclipselink.entity.Employee;
public class FindEmployee {
public static void main( String[ ] args ) {
EntityManagerFactory emfactory = Persistence.createEntityManagerFactory( "Eclipselink_JPA" );
EntityManager entitymanager = emfactory.createEntityManager();
Employee employee = entitymanager.find( Employee.class, 1201 );
System.out.println("employee ID = " + employee.getEid( ));
System.out.println("employee NAME = " + employee.getEname( ));
System.out.println("employee SALARY = " + employee.getSalary( ));
System.out.println("employee DESIGNATION = " + employee.getDeg( ));
}
}
위 프로그램을 컴파일하고 실행하면 다음과 같이 Eclipse IDE의 콘솔 패널에있는 Eclipselink 라이브러리에서 출력을 얻을 수 있습니다.
employee ID = 1201
employee NAME = Gopal
employee SALARY = 46000.0
employee DESIGNATION = Technical Manager
직원 삭제
직원을 삭제하려면 먼저 레코드를 찾은 다음 삭제합니다. 여기서 EntityTransaction은 중요한 역할을합니다.
명명 된 클래스 DeleteEmployee.java 다음과 같이 :
package com.tutorialspoint.eclipselink.service;
import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import javax.persistence.Persistence;
import com.tutorialspoint.eclipselink.entity.Employee;
public class DeleteEmployee {
public static void main( String[ ] args ) {
EntityManagerFactory emfactory = Persistence.createEntityManagerFactory( "Eclipselink_JPA" );
EntityManager entitymanager = emfactory.createEntityManager( );
entitymanager.getTransaction( ).begin( );
Employee employee = entitymanager.find( Employee.class, 1201 );
entitymanager.remove( employee );
entitymanager.getTransaction( ).commit( );
entitymanager.close( );
emfactory.close( );
}
}
위 프로그램을 컴파일하고 실행하면 Eclipse IDE의 콘솔 패널에있는 Eclipselink 라이브러리에서 알림을받습니다.
결과를 보려면 MySQL 워크 벤치를 열고 다음 쿼리를 입력하십시오.
use jpadb
select * from employee
이름이 지정된 영향을받는 데이터베이스 employee null 레코드가 있습니다.
이 예제의 모든 모듈을 완료하면 패키지 및 파일 계층이 다음과 같이 표시됩니다.