Struts报错ObjectNotFoundException的解决方法

第一种,ObjectNotFoundException

完整错误示例如下:

Struts Problem Report
Struts has detected an unhandled exception: 
Messages:    •  No row with the given identifier exists: [com.ftms.entity.JPositionTown#0] 
File:    org/hibernate/internal/SessionFactoryImpl.java
Line number:    247
________________________________________
Stacktraces
org.hibernate.ObjectNotFoundException: No row with the given identifier exists: [com.ftms.entity.JPositionTown#0] 
    org.hibernate.internal.SessionFactoryImpl$1$1.handleEntityNotFound(SessionFactoryImpl.java:247)
    org.hibernate.event.internal.DefaultLoadEventListener.load(DefaultLoadEventListener.java:210)
    org.hibernate.event.internal.DefaultLoadEventListener.proxyOrLoad(DefaultLoadEventListener.java:251)
    org.hibernate.event.internal.DefaultLoadEventListener.onLoad(DefaultLoadEventListener.java:148)
    org.hibernate.internal.SessionImpl.fireLoad(SessionImpl.java:1079)
    org.hibernate.internal.SessionImpl.internalLoad(SessionImpl.java:1006)
    org.hibernate.type.EntityType.resolveIdentifier(EntityType.java:613)
    org.hibernate.type.EntityType.resolve(EntityType.java:441)
    org.hibernate.engine.internal.TwoPhaseLoad.doInitializeEntity(TwoPhaseLoad.java:168)
    org.hibernate.engine.internal.TwoPhaseLoad.initializeEntity(TwoPhaseLoad.java:134)
    org.hibernate.loader.Loader.initializeEntitiesAndCollections(Loader.java:995)
    org.hibernate.loader.Loader.doQuery(Loader.java:874)
    org.hibernate.loader.Loader.doQueryAndInitializeNonLazyCollections(Loader.java:289)
    org.hibernate.loader.Loader.doList(Loader.java:2438)
    org.hibernate.loader.Loader.doList(Loader.java:2424)
    org.hibernate.loader.Loader.listIgnoreQueryCache(Loader.java:2254)
    org.hibernate.loader.Loader.list(Loader.java:2249)
    org.hibernate.loader.hql.QueryLoader.list(QueryLoader.java:470)
    org.hibernate.hql.internal.ast.QueryTranslatorImpl.list(QueryTranslatorImpl.java:355)
    org.hibernate.engine.query.spi.HQLQueryPlan.performList(HQLQueryPlan.java:195)
    org.hibernate.internal.SessionImpl.list(SessionImpl.java:1248)
    org.hibernate.internal.QueryImpl.list(QueryImpl.java:101)
    com.ftms.dao.UserDAO.findByProperty(UserDAO.java:112)
    com.ftms.dao.UserDAO.findByUsername(UserDAO.java:120)
    com.ftms.dao.UserDAO$$FastClassByCGLIB$$42997a1e.invoke(<generated>)
    net.sf.cglib.proxy.MethodProxy.invoke(MethodProxy.java:191)
    org.springframework.aop.framework.Cglib2AopProxy$CglibMethodInvocation.invokeJoinpoint(Cglib2AopProxy.java:689)
    org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:150)
    org.springframework.transaction.interceptor.TransactionInterceptor.invoke(TransactionInterceptor.java:110)
    org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:172)

根据博文:https://www.cnblogs.com/crazytrip/p/5355056.html

报错分析:

Hibernate 的映射文件,表 A 里关联了表 B 的主键,当查询表 A 时,在 B 表里找不到对应记录时就会报错,如果只是逻辑删除不会报这种错误,只有当表 B 里测试没有 JPositionTown为 0的这条数据了才会报错 (已实际测试过);上面报错信息实体类后面【#0】表示实体类对应表 JPositionTown=0的记录找不到。也就是存在垃圾数据,可能是因为没有连带删除,或者是数据录入有误。

解决办法:

1. 修改配置文件加上 not-found="ignore" ”

即:

<many-to-one name="JPositionTown" class="com.ftms.entity.JPositionTown" fetch="select" cascade="all" lazy="false" not-found="ignore">
<column name="town">
<comment>住址</comment>
</column>
</many-to-one>

2. 要么就把这条有问题的数据从数据库删掉。

猜你喜欢

转载自www.cnblogs.com/liesun/p/9243779.html