springmvc4+hibernate4+spring4注解一对多级联保存
package com.h3c.zgc.user.entity; import java.util.HashSet; import java.util.Set; import javax.persistence.Column; import javax.persistence.Entity; import javax.persistence.GeneratedValue; import javax.persistence.Id; import javax.persistence.JoinColumn; import javax.persistence.OneToMany; import javax.persistence.Table; import org.hibernate.annotations.Cascade; import org.hibernate.annotations.CascadeType; import org.hibernate.annotations.GenericGenerator; @Entity @Table(name="t_person",catalog="itac") public class Person { @Id @GenericGenerator(name="generator",strategy="increment") @GeneratedValue(generator="generator") @Column(name="person_id",unique=true,nullable=false) private Integer personId; @Column(name="person_name") private String personName; @OneToMany(targetEntity=House.class) @JoinColumn(name="person_id",updatable =false) @Cascade(CascadeType.SAVE_UPDATE) private Set<House> houses = new HashSet<House>(); public Set<House> getHouses() { return houses; } public void setHouses(Set<House> houses) { this.houses = houses; } public Integer getPersonId() { return personId; } public void setPersonId(Integer personId) { this.personId = personId; } public String getPersonName() { return personName; } public void setPersonName(String personName) { this.personName = personName; } @Override public String toString() { return "Person [personId=" + personId + ", personName=" + personName + ", houses=" + houses + "]"; } }
package com.h3c.zgc.user.entity; import javax.persistence.Column; import javax.persistence.Entity; import javax.persistence.GeneratedValue; import javax.persistence.Id; import javax.persistence.JoinColumn; import javax.persistence.ManyToOne; import javax.persistence.Table; import org.hibernate.annotations.Cascade; import org.hibernate.annotations.CascadeType; import org.hibernate.annotations.GenericGenerator; @Entity @Table(name="t_house",catalog="itac") public class House { @Id @GeneratedValue(generator="generator") @GenericGenerator(name="generator",strategy="increment") @Column(name="house_id",unique=true,nullable=false) private Integer houserId; @Column(name="house_address") private String houseAddress; @ManyToOne(targetEntity=Person.class) @JoinColumn(name="person_id",updatable=false) @Cascade(CascadeType.SAVE_UPDATE) private Person person; public Person getPerson() { return person; } public void setPerson(Person person) { this.person = person; } public Integer getHouserId() { return houserId; } public void setHouserId(Integer houserId) { this.houserId = houserId; } public String getHouseAddress() { return houseAddress; } public void setHouseAddress(String houseAddress) { this.houseAddress = houseAddress; } @Override public String toString() { return "House [houserId=" + houserId + ", houseAddress=" + houseAddress + "]"; } }
dao
package com.h3c.zgc.user.dao; import java.util.HashSet; import java.util.Set; import javax.annotation.Resource; import org.hibernate.SessionFactory; import org.springframework.orm.hibernate4.support.HibernateDaoSupport; import org.springframework.stereotype.Repository; import com.h3c.zgc.user.entity.House; import com.h3c.zgc.user.entity.Person; @Repository public class PersonDao extends HibernateDaoSupport{ @Resource private void set(SessionFactory sessionFactory){ this.setSessionFactory(sessionFactory); } public void savePerson(){ Person p = new Person(); p.setPersonName("person01"); this.getHibernateTemplate().save(p); } public void savePersonAndHouse(){ Person p = new Person(); p.setPersonName("person01"); House h = new House(); h.setHouseAddress("beijing"); Set<House> hs = new HashSet<House>(); hs.add(h); //建立关系 p.setHouses(hs); h.setPerson(p); this.getHibernateTemplate().save(p); System.out.println(p); } }
service
package com.h3c.zgc.user.service; import javax.annotation.Resource; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; import com.h3c.zgc.user.dao.PersonDao; @Service public class PersonService { @Resource private PersonDao personDao; @Transactional public void savePerson() { this.personDao.savePerson(); } @Transactional public void savePersonAndHouse() { this.personDao.savePersonAndHouse(); } }
controller
package com.h3c.zgc.user.controller; import java.io.IOException; import javax.annotation.Resource; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.RequestMapping; import com.h3c.zgc.user.service.PersonService; @Controller public class PersonController { @Resource private PersonService personService; @RequestMapping("savePerson") public String savePerson(HttpServletRequest request){ this.personService.savePerson(); request.setAttribute("flag", "success"); return "h4/flag"; } @RequestMapping("savePersonHouse") public String savePersonHouse(HttpServletRequest request){ this.personService.savePersonAndHouse(); request.setAttribute("flag", "success"); return "h4/flag"; } @RequestMapping("test0") public void test(HttpServletResponse response) throws IOException{ String strs = "[{ title: '中国好声音'},{ title: '中国饮料'},{ title: '中国好舞蹈'}]"; response.getWriter().write(strs); } }
访问路径
http://localhost:8080/zgc/savePersonHouse
springmvc4+hibernate4+spring4注解一对多级联保存的更多相关文章
- hibernate 一对多 级联 保存修改 删除
一对多,一端设置: <set name="TWorkorderHistories" inverse="true" cascade="all&qu ...
- 【JPA 级联保存/级联删除】@OneToMany (双向) 一对多【转】
[http://blog.sina.com.cn/s/blog_625d79410101dbdd.html] 看过前两篇帮助文档 [JPA] @OneToOne 单向 和 [JPA]@OneToO ...
- Hibernate中表与表之间的关联一对多,级联保存和级联删除
1:Hibernate的一对多操作(重点) 一对多映射配置 第一步:创建两个实体类:客户和联系人(例)以客户为一,联系人为多: package com.yinfu.entity; public cla ...
- 【j2ee spring】30、巴巴荆楚网-综合hibernate4+spring4(5)分页
巴巴荆楚网-综合hibernate4+spring4(5)分页 1.图文项目 2.首先我们引入对应的jar包 3.我们配置一下数据库中对应的实体对象 ProductType.java /** * 功能 ...
- 再谈Hibernate级联删除——JPA下的Hibernate实现一对多级联删除CascadeType.DELETE_ORPHAN
声明: 1.本文系原创,非抄袭或转载过来的. 2.本文论点都亲手做过实验论证. 3.本文所讲的Hibernate配置都基于注解的方式,hbm语法未提供. 非常多人对持久层概念搞不清JPA.Hibern ...
- 【j2ee spring】27、巴巴荆楚网-整合hibernate4+spring4(2)
巴巴荆楚网-整合hibernate4+spring4(2) 1.图文项目 2.首先我们引入对应的jar包 这里用的是oracle 11g,所以我们使用的数据库连接jar包是ojdbc6, 的区别就是支 ...
- Hibernate学习(三)一对多数据的保存
保存习惯代码 @Test public void saveTwoTableTest(){ Transaction transaction = null; try { transaction = ses ...
- Hibernate入门(八)级联保存或更新(含问题在末尾,求大佬指点..)
级联保存或更新CASCADE 级联保存或更新: 作用就是:保存一方的数据的时候,会把关联的对象也同时保存. 级联保存或更新的配置: 属性名:cascade 属性值: 1.none:所有情况下均不进行关 ...
- Hibernate一对多关联关系保存时的探究
在以前使用hibernate时,经常对保存存在关联关系的对象时,不确定是否能保存成功. 因此,特意对一对多关系的2个对象进行实践. 一.pojo类和配置文件的准备 这里有一点提前 ...
随机推荐
- Redis的几个认识误区
此文作者是新浪微博平台架构师杨卫华timyang大师,是他对Redis研究的一个总结,澄清了一些认识上的误区,值得一读. James Hamilton在On Designing and Deployi ...
- AOP动态代理解析2-代码织入入口
通过自定义配置完成了对AnnotationAwareAspectJAutoProxyCreator类型的自动注册,那么这个类到底做了什么工作来完成AOP的操作呢?首先我们看看AnnotationAwa ...
- Swift3.0语言教程获得一个公共的前缀
Swift3.0语言教程获得一个公共的前缀 Swift3.0语言教程获得一个公共的前缀,当在一个程序中有多个字符串时,我们需要判断是否有两个字符串有公共的前缀时,是很困难的.在NSString中的co ...
- idea 使用
1.idea对maven的兼容性优于eclipse,idea对于程序内部管理是模块,个人感觉也是优于eclipse. 2.idea默认设置编辑器字体是比较差的. 可以参考文章 http://www.3 ...
- redis 的使用 (基础, key操作, string类型操作)
使用redis set 类型: 没有重复元素 list 链表类型 有重复累型 sort set 类型 没有重复元素 1.1 存储数据 读取数据 // 数据储存在 内存中 set name laowen ...
- BIT LA 4329 Ping pong
题目传送门 题意:训练指南P197 分析:枚举裁判的位置,用树状数组来得知前面比它小的和大的以及后面比它小的和大的,然后O (n)累加小 * 大 + 大 * 小 就可以了 #include <b ...
- LightOJ1283 Shelving Books(DP)
题目 Source http://www.lightoj.com/volume_showproblem.php?problem=1283 Description You are a librarian ...
- BZOJ4707 : B君的技巧
建立线段树,设$f[x][l][r]$表示当前考虑$x$点,最左端是$l$,最右端是$r$的最少代价. 如果$a$在$x<<1$,$d$在$x<<1|1$, 设$g[a][c] ...
- [数据库]关于MAX()函数的一个坑
之前写了这么一条sql语句,目的是取出表中itemid最大的那一条数据. SELECT date, MAX(itemid) AS itemid, group FROM mytable GROUP BY ...
- 使用for( var each in record){} 去寻找object里面的内容;
for(var each in object){ alert(each); }