hibernate级联处理问题

hibernate进行级联处理时,关于一对一的关系应该注意的问题。

1、假如有奖品项item和奖品aword,他们之间的对应关系是

1)item      1:1    aword
奖品项与奖品是一对一的关系,一个奖品项只能包含一个奖品。

2)aword   1:n    item
奖品与奖品项是一对多的关系,一个奖品可以出现在多个奖品项中。

2、在进行hibernate注解配置的时候,他们的关系应该如下:

1)entity   Item

<span style="white-space:pre">	</span>//红包,一对一
<span style="white-space:pre">	</span>//将在item表中创建awordId字段。
<span style="white-space:pre">	</span>//级联只选择更新,表示数据更新时,item更新,这里不要级联删除,因为奖品项删除不会影响到奖品
<span style="white-space:pre">	</span>@ManyToOne(cascade = {CascadeType.REFRESH}, fetch = FetchType.LAZY,optional = true)
<span style="white-space:pre">	</span>@JoinColumn(name = "awordId")
<span style="white-space:pre">	</span>private Aword aword;

2)entity  aword

	//红包与转盘的奖品项是一对多的关系,如果删除红包,那么红包对应的所有大转盘奖项也应该删除。
<span style="white-space:pre">	</span>//mappedBy字段表明关联到item表中的aword,关联关系有aword来维护,如果奖品删除了,那么对应的所有的奖品项也要删除
	@OneToMany(mappedBy="aword" , cascade = {CascadeType.REMOVE,CascadeType.REFRESH},fetch = FetchType.LAZY)
	private List<Item> items;

3、有了以上的hibernate级联关系后,删除奖品项,不会影响到奖品,那么也不会影响到其他使用了这个奖品的奖品项。这里还需要注意几点:

1)在数据库中,需要在奖品项item中添加外键字段awordId,因此可以通过这个奖品id取出对应的奖品。

2)在做奖品aword删除时,切记要使用hibernate的delete删除方法,如果删除多个奖品,就用for循环删除。不能使用hibernate调用query方法,不能去使用sql删除数据,否则会绕过hibernate机制,不会进行级联删除等操作。有些类似于spring的session,如果你自己openSession,那么这个session就需要自己打开关闭,并且还需要放在事务中处理。但是如果使用getCurrentSession,那么spring会帮你管理这个session,前提你需要在spring配置文件中配置事务。

4、hibernate如果使用延迟加载机制,如果使用调试,那么调试的数据是看不到的,需要打印,如奖品项item,如果使用延迟加载,调试是看不到item的数据的,如果想看item的某一个数据,可以打印这个数据。

hibernate延迟加载只会将数据保存在session中(未确认),那么如果你在dao层去数据,那么在service层使用数据时,数据可能报错,原因时数据取出来后session就会关闭,那么其他层,或者web就不能得到数据。解决这个问题的方法是,让延迟加载的范围扩大到一次请求,可以在web.xml中配置监听器进行处理。

	<!-- 将hibernate延迟加载扩展到一次请求,而不是一个session的范围 -->
	<filter>
		<filter-name>hibernateOpenSessionInViewFilter</filter-name>
		<filter-class>
			org.springframework.orm.hibernate3.support.OpenSessionInViewFilter</filter-class>
	</filter>
	<filter-mapping>
		<filter-name>hibernateOpenSessionInViewFilter</filter-name>
		<url-pattern>/*</url-pattern>
	</filter-mapping>

版权声明:本文为博主原创文章,未经博主允许不得转载。

时间: 2024-10-05 04:33:35

hibernate级联处理问题的相关文章

hibernate级联保存,更新个人遇到的问题

在级联更新的时候,数据库中的数据是增加的,只是外键不存在,导致这样的问题产生的原因是,字表主键ID没有添加到集合中,导致Hibernate找不到子项而执行更新. hibernate级联保存,更新个人遇到的问题,布布扣,bubuko.com

hibernate 级联删除报更新失败的问题(org.hibernate.exception.GenericJDBCException: Could not execute JDBC batch update)

首先hibernate级联删除的前提是,首先需要在映射文件中配置,配置多表之间的关联关系: 下面以部门表(Dept)和员工表(Emp)为例: 1.在Emp.hbm.xml映射文件中配置many-to-one关系 1 <?xml version="1.0"?> 2 <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" 3 "http:/

hibernate级联保存问题

今天的遇到一个问题,搞了半天.做个记录 hibernate级联保存,设置了cascade关系,但新增时总是主表insert,从表update.以下为报错信息: Batch update returned unexpected row count from update [0]; actual row count: 0; expected: 1 网上的解释是id冲突导致的,即数据库中定义了id自增,而类被插入时也被赋予了id. 解决办法:将数据库id自增去掉,重新生成类文件,选择id自增策略选择i

hibernate级联

cascade和inverse (Employee – Department) Casade用来说明当对主对象进行某种操作时是否对其关联的从对象也作类似的操作,常用的cascade: none,all,save-update,delete, lock,refresh,evict,replicate,persist, merge,delete-orphan(one-to-many).一般对many-to-one,many-to-many不设置级联,在<one-to-one>和<one-to

Hibernate级联操作解密(inverse和cascade)

总结: Cascade:对级联操作进行限制,有如下几个参数: all : 所有情况下均进行关联操作.  none:所有情况下均不进行关联操作.这是默认值.  save-update:在执行save/update/saveOrUpdate时进行关联操作.  delete:在执行delete时进行关联操作. Inverse:在一对多模型中,只能在一的一方设置,inverse的作用就是在级联发生后,会再次更新子表数据的外键为主表的主键.确保子表外键不会为空. 下面演示一个班级学生的例子(一对多): 班

再谈Hibernate级联删除——JPA下的Hibernate实现一对多级联删除CascadeType.DELETE_ORPHAN

声明: 1.本文系原创,非抄袭或转载过来的. 2.本文论点都亲手做过实验论证. 3.本文所讲的Hibernate配置都基于注解的方式,hbm语法未提供. 非常多人对持久层概念搞不清JPA.Hibernate.EJB3.0的关系,这里做一下简单的说明:JPA是一个持久层设计接口,EJB3.0和Hibernate是详细的实现类,EJB3.0和Hibernate的功能近似相等的(Hibernate没有Session Bean,Spring MVC3的SessionAttribute跟Session B

hibernate级联删除

一对多的双向关联:user对应多个order user.xml: <class name="com.examp.ShoppingOnline.User"             table="user"            discriminator-value="C">                       <id name="id">             <generator cl

Hibernate 级联之OneToMany

首先看看表结构! customer表: create table customers (     ID bigint not null    primary key auto_increment,     userName varchar(20) ); Order表: create table orders (     ID bigint not null primary key auto_increment,     customers_ID bigint,    --应该为customers

Hibernate级联操作和加载机制(二) cascade and fetch

上一篇介绍了Hibernate持久化对象时候的级联操作,本篇介绍读取时候的级联操作. 还是用上一篇的例子,一份问卷有多个问题,但是每个问题只能属于一份问卷.我们先看测试用例: @Test public void testReadFromQuestionnaire(){ Session session = sessionFactory.getCurrentSession(); session.beginTransaction(); Questionnaire qn = (Questionnaire