hibenate 계승 관계 모델 의 디자인
조직 표 (상하 관계 존재) 예 를 들 어 본사, 지사, 부서.
데이터베이스 에서 디자인
id 와 pid 를 통 해 이러한 계승 관 계 를 실현 합 니 다.
CREATE TABLE `org` (
`id` int(11) NOT NULL default '0',
`pid` int(11) default NULL,
`name` varchar(40) default NULL,
PRIMARY KEY (`id`),
KEY `pid` (`pid`),
CONSTRAINT `org_ibfk_1` FOREIGN KEY (`pid`) REFERENCES `org` (`id`) ON UPDATE CASCADE
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
실천 응용 에서 역방향 공 사 를 통 해 대응 하 는 Org 류 를 생 성 할 수 있 습 니 다. 그의 소스 코드 를 살 펴 보 겠 습 니 다.
대상 을 대상 으로 하 는 클래스 의 디자인 은 org 를 하나의 링크 로 집합 하 는 것 입 니 다. 이 조직 아래 에 분기 가 있 으 면 set 집합 에 값 이 있 습 니 다.(왜 set 입 니까? 모든 조직의 id 가 유일 하 게 표 시 됩 니 다)
import java.util.HashSet;
import java.util.Set;
import javax.persistence.CascadeType;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.FetchType;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.ManyToOne;
import javax.persistence.OneToMany;
import javax.persistence.Table;
/**
* Org entity. @author MyEclipse Persistence Tools
*/
@Entity
@Table(name = "org", catalog = "hibernate")
public class Org implements java.io.Serializable {
// Fields
/**
*
*/
private static final long serialVersionUID = 1L;
private Integer id;
private Org org;
private String name;
private Set<Org> orgs = new HashSet<Org>(0);
// Constructors
/** default constructor */
public Org() {
}
/** minimal constructor */
public Org(Integer id) {
this.id = id;
}
/** full constructor */
public Org(Integer id, Org org, String name, Set<Org> orgs) {
this.id = id;
this.org = org;
this.name = name;
this.orgs = orgs;
}
// Property accessors
@Id
@Column(name = "id", unique = true, nullable = false)
public Integer getId() {
return this.id;
}
public void setId(Integer id) {
this.id = id;
}
@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name = "pid")
public Org getOrg() {
return this.org;
}
public void setOrg(Org org) {
this.org = org;
}
@Column(name = "name", length = 40)
public String getName() {
return this.name;
}
public void setName(String name) {
this.name = name;
}
@OneToMany(cascade = CascadeType.ALL, fetch = FetchType.LAZY, mappedBy = "org")
public Set<Org> getOrgs() {
return this.orgs;
}
public void setOrgs(Set<Org> orgs) {
this.orgs = orgs;
}
}
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
[JPA] 즉시로딩(EAGER)과 지연로딩(LAZY) (왜 LAZY 로딩을 써야할까?) (1)Proxy는 이 글의 주제인 즉시로딩과 지연로딩을 구현하는데 중요한 개념인데, 일단 원리는 미뤄두고 즉시로딩과 지연로딩이 무엇인지에 대해 먼저 알아보자. 눈 여겨 볼 곳은 'fetch = FetchType.EAGER...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.