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;
	}

}

좋은 웹페이지 즐겨찾기