• 查询时报第一页没有数据,第二页有数据的异常


    今天遇到的问题:

    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,如果找不到就抛出异常 。

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

  • 相关阅读:
    PHP+NGINX
    mysql添加索引
    SecureFX 乱码问题
    kali ssh服务连接问题,无法远程管理
    Nginx安装配置
    redhat mysql安装配置
    shell脚本-1
    Improved Semantic Representations From Tree-Structured Long Short-Term Memory Networks-paper
    Parsing with Compositional Vector Grammars--paper
    Reasoning With Neural Tensor Networks For Knowledge Base Completion-paper
  • 原文地址:https://www.cnblogs.com/stujike/p/8573546.html
Copyright © 2020-2023  润新知