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>




你可能感兴趣的:(hibernate级联处理问题)