假设两个对象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() ;
}
分享到:
相关推荐
一键生成指令php think curd(关联语句+sql文件) EasyAdmin框架以内置快速生成CURD的命令, 包括控制器、视图、模型、JS文件。能够使开发者效率得到进一步提升。 备注:在进行CURD命令行之前, 请按照规范设计表结构, ...
thinkPHP之CURD开发简单源码,适合新手学习
SpringMVC之CURD小Demo适合新手学习,没有具体的链接数据库,利用map保存数据,相当于数据库,新手学习阶段自己的一些总结,希望能帮到大家
angularjs CURD Example 单页应用程序
vue简单curd例子。
curd oracle. curd oracle. curd oracle.
通过ext实现sqlserver数据表的CURD,界面友好,datagrid分页显示数据,下下来可以直接用的哦
Hibernate构建一个CURD的程序
这个是简单的MVC3+LINQ进行数据库CURD的操作 适合新手入门学习
奉献出来,包含了gird的curd,tree的curd,4种页面布局,一个dataview实例,这些足够吧!
ThinkPHP CURD操作的查询方法中最常用但也是最复杂的就是where方法。where方法也属于模型类的连贯操作方法之一,主要用于查询和操作条件的设置。 where方法的用法是ThinkPHP查询语言的精髓,也是ThinkPHP ORM(对象...
Android SQLite数据库的CURD 简单的数据库的CURD 没啥特殊的 做了一个跳转
ThinkPHP CURD方法的field方法属于模型的连贯操作方法之一,主要目的是标识要返回或者操作的字段,可以用于查询和写入操作。 1、用于查询 在查询操作中field方法是使用最频繁的。 $Model->field('id,title,content'...
主要介绍了ThinkPHP CURD方法的limit方法,需要的朋友可以参考下
这是关于postgreSQL的开发demo,利用jdbc、hibernate、ibatis三种方式去调用postgreSQL的CURD和存储过程。
page方法是完全为分页查询而诞生的一个人性化操作方法这篇文章主要介绍了ThinkPHP CURD方法的page方法,需要的朋友可以参考下
thinkphp CURD完整案例,控制器,配置文件,增删查改完成案例,带数据库。新建数据库study ,然后导入my_study.sql文件。
最新的winform三层CURD操作 附加DB 可以正常运行
jpa的自定义CURD,简单易懂。