码迷,mamicode.com
首页 > Web开发 > 详细

hibernate 多对一(级联)操作

时间:2016-05-11 19:52:53      阅读:216      评论:0      收藏:0      [点我收藏+]

标签:

级联:当你存储一个表的内容想值得相关联的表也存储数据时,可以通过级联来实现(cascade)
@Entity
@Table(name="t_User")
public class User {
private int id;
private String name;
private Grup grup;
@ManyToOne(cascade={CascadeType.ALL})
//all:意为级联全部,牵一发而动全身,只要是其中一个表进行数据库操作,另一个也会跟着进行操作
public Grup getGrup() {
return grup;
}
public void setGrup(Grup string) {
this.grup = string;
}
@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;
}
public User(int id, String name) {
super();
this.id = id;
this.name = name;
}
public User() {
}
}


test单元测试:按道理,可以分别存储user和grup的内容,但是结果不是这样的,grup的内容是空值,这时级联就登上表演舞台
public class ManyToOneTest {
@Test
public void testSaveUser() {
User u = new User();
u.setName("Judy");
Grup g =new Grup();
g.setName("Linda");
u.setGrup(g);;
@SuppressWarnings("deprecation")
SessionFactory sessionFactory = new AnnotationConfiguration().configure().buildSessionFactory();
Session session =sessionFactory.getCurrentSession();
session.beginTransaction();
session.save(u);
session.getTransaction().commit();
}

}

由结果可知,数据已经插入到对应的表中

技术分享

技术分享
注意:级联只是可以让写程序的人在操作过程中较为省事,但是并非必需要用到,如果想要把多表的数据内容分先后顺序,完全可以手动存储,不用级联操作。

hibernate 多对一(级联)操作

标签:

原文地址:http://www.cnblogs.com/LindaBlog/p/5483165.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!