zoukankan      html  css  js  c++  java
  • 查询时报第一页没有数据,第二页有数据的异常

    今天遇到的问题:

    1、查到的资料显示这是一个hibernate 中 常见的问题

    2、下面说说这个问题出现的原因和解决方法:

    产生此问题的原因:

                 有两张表,table1table2.产生此问题的原因就是table1里做了关联<one-to-one>或者<many-to-one unique="true">

    (特殊的多对一映射,实际就是一对一)来关联table2.当hibernate查找的时候,table2里的数据没有与table1相匹配的,

    这样就会报No row with the given identifier exists这个错.(一句话,就是数据的问题!)

    hibernate的查询的比较
    hibernate的查询有很多,Query,find,Criteria,get,load

    query使用hsql语句,可以设置参数是常用的一种方式

    criteria的方式,尽量避免了写hql语句,看起来更面向对象了。

    find方式,这种方式已经被新的hibernate丢弃

    get和load方式是根据id取得一个记录
    下边详细说一下get和load的不同,因为有些时候为了对比也会把find加进来。

    1,从返回结果上对比:
    load方式检索不到的话会抛出org.hibernate.ObjectNotFoundException异常
    get方法检索不到的话会返回null

    2,从检索执行机制上对比:
    get方法和find方法都是直接从数据库中检索
    而load方法的执行则比较复杂
    1,首先查找session的persistent Context中是否有缓存,如果有则直接返回
    2,如果没有则判断是否是lazy,如果不是直接访问数据库检索,查到记录返回,查不到抛出异常
    3,如果是lazy则需要建立代理对象,对象的initialized属性为false,target属性为null
    4, 在访问获得的代理对象的属性时,检索数据库,如果找到记录则把该记录的对象复制到代理对象的target
    上,并将initialized=true,如果找不到就抛出异常 。

    所以,出现上述的问题 绝对是数据库的问题!!!查看控制台 报的异常后面的信息,就是那一条数据的问题。不要怀疑,就它就它!!

  • 相关阅读:
    BZOJ 2654: tree
    洛谷P1972[SDOI2009]HH的项链
    洛谷 P3833 [SHOI2012]魔法树
    P2167 [SDOI2009]Bill的挑战
    洛谷 P2145 [JSOI2007]祖码
    洛谷 P4170 [CQOI2007]涂色
    P2024 [NOI2001]食物链
    USACO 2012 December ZQUOJ 24122 Scrambled Letters(二分)
    USACO 2012 December ZQUOJ 24128 Wifi Setup(动态dp)
    2013长春网赛1009 hdu 4767 Bell(矩阵快速幂+中国剩余定理)
  • 原文地址:https://www.cnblogs.com/stujike/p/8573546.html
Copyright © 2011-2022 走看看