056:hibernate树状结设计(至关重要)

1、parient_id实际上为一个连接字段。

对于org.java:

package com.bjsxt.hibernate;

import java.util.HashSet;
import java.util.Set;

import javax.persistence.CascadeType;
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.OneToMany;

@Entity
public class Org {
	private int id;
	private String name;
/*定义一个孩子*/	private Set<Org> children = new HashSet<Org>();
/*定义一个父亲*/	private Org parent;
	@Id
	@GeneratedValue
	public int getId() {
		return id;
	}
	public void setId(int id) {
		this.id = id;
	}
	public String getName() {
		return name;
	}
	public void setName(String name) {
		this.name = name;
	}
	@OneToMany(cascade=CascadeType.ALL, mappedBy="parent")
	public Set<Org> getChildren() {
		return children;
	}
	public void setChildren(Set<Org> children) {
		this.children = children;
	}
	
	@ManyToOne
	@JoinColumn(name="parent_id")
	public Org getParent() {
		return parent;
	}
	public void setParent(Org parent) {
		this.parent = parent;
	}
}


@ManyToOne      //多个org对应一个父亲。

@OneToMany(cascade=CascadeType.ALL, mappedBy="parent")

关于mappedBy的含义
a) 只有OneToOne,OneToMany,ManyToMany上才有mappedBy属性,ManyToOne不存在该属性;
b) mappedBy标签一定是定义在the owned side(被拥有方的),他指向the owning side(拥有方);
c) mappedBy的含义,应该理解为,拥有方能够自动维护跟被拥有方的关系;
2、
package com.bjsxt.hibernate;

import java.util.Map;

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.AnnotationConfiguration;
import org.hibernate.tool.hbm2ddl.SchemaExport;
import org.junit.AfterClass;
import org.junit.BeforeClass;
import org.junit.Test;

public class HibernateTreeTest {
	private static SessionFactory sessionFactory;
	
	@BeforeClass
	public static void beforeClass() {
		new SchemaExport(new AnnotationConfiguration().configure()).create(false, true);
		sessionFactory = new AnnotationConfiguration().configure().buildSessionFactory();
	}
	@AfterClass
	public static void afterClass() {
		sessionFactory.close();
	}
	
	@Test
	public void testSave() {
		Org o = new Org();
		o.setName("总公司");
		Org o1 = new Org();
		o1.setName("分公司1");
		Org o2 = new Org();
		o2.setName("分公司2");
		Org o11 = new Org();
		o11.setName("分公司1下部门1");
		Org o12 = new Org();
		o12.setName("分公司1下部门2");
		
		o.getChildren().add(o1);
		o.getChildren().add(o2);
		o1.getChildren().add(o11);
		o1.getChildren().add(o12);
		o11.setParent(o1);
		o12.setParent(o1);
		o1.setParent(o);
		o2.setParent(o);
				
		
		Session session = sessionFactory.openSession();
		session.beginTransaction();
		session.save(o);
	
		session.getTransaction().commit();
		session.close();
	}
	@Test
	public void testLoad() {
		testSave();
		Session session = sessionFactory.openSession();
		session.beginTransaction();
		Org o = (Org)session.load(Org.class, 1);
		print(o, 0);
		session.getTransaction().commit();
		session.close();
		
	}
	
	private void print(Org o, int level) {
		String preStr = "";
		for(int i=0; i<level; i++) {
			preStr += "----";
		}
		System.out.println(preStr + o.getName());
		for(Org child : o.getChildren()) {
			print(child, level+1);
		}
	}
	@Test
	public void testSchemaExport() {
		new SchemaExport(new AnnotationConfiguration().configure()).create(false, true);
	}
	
	
	public static void main(String[] args) {
		beforeClass();
	}
}

往里面做存储

  先做几个Org

                public void testSave() {

                            Org o = new Org();

                           o.setName("总公司");

                           Org o1 = new Org();

                            o1.setName("分公司1");

                            Org o2 = new Org();

                           o2.setName("分公司2");

                            Org o11 = new Org();

                             o11.setName("分公司1下部门1");

                               Org o12 = new Org();

                               o12.setName("分公司1下部门2");

       存储的时候,先存父亲o,然后设他的父亲是谁o1,然后再存分公司1,分公司2,也可以在org.java加入cascade=CascadeType.ALL,在程序里设好双方关系。

          先设孩子的关系:

        o.getChildren().add(o1);
       o.getChildren().add(o2);
       o1.getChildren().add(o11);
       o1.getChildren().add(o12);

       再设父亲关系:

        o11.setParent(o1);
        o12.setParent(o1);
        o1.setParent(o);
        o2.setParent(o);

o就 不用再设了,默认就是一个空值。

3、创建 session

Session session = sessionFactory.openSession();
		session.beginTransaction();
		session.save(o);
	
		session.getTransaction().commit();
		session.close();


最后session.save(o);

前面用的openSession(),则后面要close()掉,----->session.close();


@Beforclass里面已经输出表了,main里面调了beforeclass直接执行main方法就可以。

4、在hibernate.cfg.xml中:
<mapping classs="com.bjsxt.hibernate.Org">
 
5、若要把它读出来,则要用递归。
    
@Test
	public void testLoad() {
		testSave();
		Session session = sessionFactory.openSession();
		session.beginTransaction();
		//首先要把父亲的org拿出来。
		Org o = (Org)session.load(Org.class, 1);//先把顶上拿出来
		
		//若要拿它的孩子,则要用用递归
		print(o, 0);
		session.getTransaction().commit();
		session.close();
		
	}
	

若要拿它的孩子,则要用用递归,在org.java中加:fetch=FetchType.EAGER,这样load父亲的时候,孩子就 跟着出来了。
	private void print(Org o) {
	        System.out.println( o.getName());//先把名字打印出来,然后去拿孩子
		for(Org child : o.getChildren()) {
			print(child);
		}
	}
如果把它展现为树状,则将print(o)改为print(o,0)
                                           将private   void  print(Org  o,int  level)
                           level是用来产生前央的树状缩进
即:
private void print(Org o, int level) {
		String preStr = "";
		for(int i=0; i<level; i++) {
			preStr += "----";
		}
		System.out.println(preStr + o.getName());
		for(Org child : o.getChildren()) {
			print(child, level+1);
		}
	}

 
 
 

 
 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值