hibernate可以很简单的实现数据库中的各种关系
下面是一个单向一对多的例子
假设一个渣男有多个女朋友 一个简单的单向一对多的例子
首先需要在配置文件中配置两个pojo
<mapping class="qdm.entity.onetomany.GarbageMan" /> <mapping class="qdm.entity.onetomany.Girl" />
下面是使用注解的方式自动生成数据库中的表
@Entity @Table(name="tb_garbageman") public class GarbageMan { @Id @GeneratedValue(strategy = GenerationType.AUTO) private int id; public int getId() { return id; } public void setId(int id) { this.id = id; } @Column(name="gname") private String name;
/*
这里是一对多的配置 在“一”的一方配置多的属性 由“一”主导多方,在级联时,可以通过添加一方来级联添加多方
@Cascade(value = CascadeType.SAVE_UPDATE)
这里要用hibernate
*/
@OneToMany @Cascade(value = CascadeType.SAVE_UPDATE) @JoinColumn(name="gilrs") private List<Girl> girlList=new ArrayList<Girl>(); public GarbageMan() { } public GarbageMan(String name) { this.name=name; } public String getName() { return name; } public void setName(String name) { this.name = name; } public List<Girl> getGirlList() { return girlList; } public void setGirlList(List<Girl> girlList) { this.girlList = girlList; } }
@Entity @Table(name="tb_girl") public class Girl { @Id @GeneratedValue(strategy = GenerationType.AUTO) private int id; private String name; public Girl() { } public Girl(String name) { this.name = name; } 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; } }
下面是测试代码
public class Test { public static void oneToManyTest() { Girl g1=new Girl("你好"); Girl g2=new Girl("渣男"); GarbageMan man=new GarbageMan("渣男"); man.getGirlList().add(g1); man.getGirlList().add(g2); Session session= Hibernate.getSession(); session.beginTransaction(); session.save(man); session.getTransaction().commit(); } public static void main(String[] argv) { oneToManyTest(); } }
。
从数据库看 我们在代码中只添加了man一个实体,但是级联添加了其他属性