使用@ManyToOne并延时加载出现的问题以及解决总结

出现的问题:

使用HIBERNATE的注解@ManyToOne(fetch = FetchType.lazy) 时候,报出错误 

org.hibernate.LazyInitializationException: could not initialize proxy - no Session
at org.hibernate.proxy.AbstractLazyInitializer.initialize(AbstractLazyInitializer.java:167)
at org.hibernate.proxy.AbstractLazyInitializer.getImplementation(AbstractLazyInitializer.java:215)
at org.hibernate.proxy.pojo.javassist.JavassistLazyInitializer.invoke(JavassistLazyInitializer.java:190)
at com.evolution.warlock.entity.Department_$$_javassist_1.getName(Department_$$_javassist_1.java)
at org.apache.shiro.authc.pam.ModularRealmAuthenticator.doSingleRealmAuthentication(ModularRealmAuthenticator.java:180)
at org.apache.shiro.authc.pam.ModularRealmAuthenticator.doAuthenticate(ModularRealmAuthenticator.java:267)
at org.apache.shiro.authc.AbstractAuthenticator.authenticate(AbstractAuthenticator.java:198)


造成这个问题的原因:

fetch=FetchType.LAZY就等于打开了延迟加载,
Hibernate中的get方法不论是否开启延迟加载都会一次加载所有基本数据类型属性的值,
而load则不同,开启延迟加载后load(id),返回的对象会被Hibernate加一个壳(持久化上下文中没有缓存该对象的前提下),拦截所有非id属性的访问操作(getter,setter调用),
只有id属性中有实际值(其实就是你调用load方法时传的那个),在session没有关闭的之前,如果访问除id外的其他属性才会发sql语句去查询,
这个错误就是因为在当前session关闭以后访问由load()加载的对象的非id属性,此时Hibernate尝试通过当前session发sql查询,但发现session已经关闭,这样才会报错。


解决办法:

测试发现的确是上面所说的,LAZY阻挡了除ID以外的所有访问,所以解决的办法就很多, 
一.就是只拿ID,再从数据库从新拿一次你需要的东西。 
二.将FetchType.lazy 改成 EAGER 
三.配置xml (没试过) 

      在web.xml配置:

<filter>
  <filter-name>openSessionInView</filter-name>
  <filter-class>org.springframework.orm.hibernate3.support.OpenSessionInViewFilter</filter-class>
</filter>

<filter-mapping>
  <filter-name>openSessionInView</filter-name>
  <url-pattern>/*</url-pattern>
</filter-mapping>

四.在service层使用Hibernate.initialize()将你需要的对象从新持久化 


原文地址:

http://wxynxyo.iteye.com/blog/2007415
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: @onetomany和@manytoone是Hibernate框架中的注解,用于描述实体类之间的关系。 @onetomany表示一对多的关系,即一个实体类对应多个另一个实体类的对象。例如,一个班级对应多个学生,可以使用@onetomany注解来描述这种关系。 @manytoone表示多对一的关系,即多个实体类对应一个另一个实体类的对象。例如,多个订单对应一个客户,可以使用@manytoone注解来描述这种关系。 ### 回答2: @onetomany和@manytoone是数据库中两种常见的关系映射,用来描述表与表之间的关系。其中,@onetomany表示一个实体与多个实体的关系,@manytoone表示多个实体与一个实体的关系。 @onetomany关系映射可以理解为“一对多”的关系,也就是说一个表中的记录可以对应到另一个表中的多条记录。比如说,一个学院可以有多个专业,那么学院表和专业表之间就可以使用@onetomany来描述这种关系。在实际操作中,通常会在多的那一方定义一个外键,用来关联到“一”的那一方的主键上。 @manytoone关系映射则可以理解为“多对一”的关系,也就是说多个表中的记录可以对应到另一个表中的同一条记录。比如说,多个学生可以属于同一个班级,那么学生表和班级表之间就可以使用@manytoone来描述这种关系。在实际操作中,通常会在“多”那一方定义一个外键,用来关联到“一”的那一方的主键上。 需要注意的是,@onetomany和@manytoone只是关系映射的一种方式,在实际应用中还需要根据具体情况来选择适合的方式。此外,在使用时还需要注意关系的维护和数据的一致性,避免出现关系错乱或者数据冗余等问题。 ### 回答3: @onetomany和@manytoone是两种不同的映射关系,通常应用于关系型数据库中的表之间的联系。 @onetomany指的是一对多的关系,也就是说,一个实体(或对象)与另一个实体(或对象)之间存在一对多的关联关系。在关系型数据库中,这种关系通常通过外键来实现,也就是在多的一端(子表)中添加一列,该列保存着主表的主键,从而实现与主表的关联。应用程序中查询多的一端时,可以通过ORM框架将查询结果映射到对应的实体对象中,从而方便进行数据操作和处理。 @manytoone则与@onetomany相反,它指的是多对一的关系。在关系型数据库中,这种关系通常通过在多的一端(子表)中添加外键来实现。应用程序中,查询的结果和处理都与@onetomany类似。 这两种映射关系在企业级开发中非常常见,经常被用于开发各种业务系统。例如,在一个订单管理系统中,一个客户可以对应多个订单,这就是一个@onetomany的关系。而一个订单只能对应一个客户,这就是一个@manytoone的关系。只有深入理解这两种关系的含义和使用方法,才能在实际开发中灵活运用ORM框架。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值