学习笔记8——关联关系CURD之save方法

假设两个对象User和Group,在数据库模型上Group为主表,User为从表,属于一对多的关系。
hibernate进行save操作时候,如何进行联级操作。
普通的做法:在session事务中先进行主表的save操作,使对象转化为persisent状态,再进行从表User的save操作。

@Test
public void testSaveUser(){
User u = new User();
u.setName("CZS") ;
Group g = new Group();
g.setName("g1") ;
//g.setId(1) ;
u.setGroup(g) ;
Session session = sessionFactory.getCurrentSession() ;
session.beginTransaction() ;
session.save(g) ;
session.save(u) ;
session.getTransaction().commit() ;
}


那么当我们想,已经在表之中确定好两个表之间的关系,如何在hibernate进行子表操作的时候同时自动操作主表对象,让hibernate自动进行联级操作?
可以在对象模型的@ManyToOne中设定属性cascade[]:
@ManyToOne(cascade={CascadeType.ALL})

@ManyToOne(cascade={CascadeType.ALL})
@JoinColumn(name="t_groupid")
public Group getGroup() {
return group;
}
public void setGroup(Group group) {
this.group = group;
}


进行Save:

@Test
public void testSaveUser(){
User u = new User();
u.setName("CZS") ;
Group g = new Group();
g.setName("g2") ;
//g.setId(1) ;
u.setGroup(g) ;
Session session = sessionFactory.getCurrentSession() ;
session.beginTransaction() ;
//session.save(g) ;
session.save(u) ;
session.getTransaction().commit() ;
}



同理存储主表级联子表操作在主表对象加入@OneToMany(cascade={CascadeType.ALL}):

@OneToMany(mappedBy="group",cascade={CascadeType.ALL})
public Set<User> getUsers() {
return users;
}
public void setUsers(Set<User> users) {
this.users = users;
}


session操作则比较麻烦,需要相互设置两个对象模型之间的关系:

@Test
public void testSaveGroup(){
User u1 = new User();
u1.setName("CZS") ;
User u2 = new User() ;
u2.setName("LMY") ;
Group g = new Group();
g.setName("g1") ;
Set<User> users = new HashSet<User>() ;
users.add(u1) ;
users.add(u2) ;
g.setUsers(users) ;
u1.setGroup(g) ;
u2.setGroup(g) ;
Session session = sessionFactory.getCurrentSession() ;
session.beginTransaction() ;
session.save(g) ;
session.getTransaction().commit() ;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值