teleport01 2009-04-21 10:04
浏览 1086
已采纳

使用hql查询,为什么一行数据中其中一个字段的值为空,那么返回的list包含的对象就是null!

使用hql查询,为什么一行数据中其中一个字段的值为空,那么返回的list包含的对象就是null!
先说说我的hibernate配置文件。因为我所操作的表是没有主键的,所以配置文件格式大致如下:
[code="java"]


















[/code]
我通过hibernate的Query接口操作hql返回list集合。
[code="java"]
String hql = "FROM Cibaseinfo U WHERE 1=1";
List result = query.createQuery(hql);
[/code]
如果说表里的数据每个字段的值都是饱满的,那么遍历出来的list里面就是Cibaseinfo对象。
如果表里的一行数据其中任何一个(包含一个以上)字段的值为空,那么遍历list之后得到的就是一个null。
请教各位这是什么原因引起的,是不是和我的配置文件无主键这种方式有关,谢谢。
[b]问题补充:[/b]
请教lovewhzlq
http://www.iteye.com/problems/15308
可否全部写成可为空的字段?

  • 写回答

3条回答 默认 最新

  • wanghaolovezlq 2009-04-21 10:41
    关注

    你这种配置和代码应该是用myeclipse自动生成的


    在composite-id里的key-property必须是非空字段,
    因为hibernate查询时是根据composite-id里的key-property来唯一判断查询的

    [code="java"]


    //这里面的都为非空字段,












    //下面的为可空字段






    [/code]

    类的代码也要做相应修改才行

    Cibaseinfo
    CibaseinfoId id
    Long custType
    String NAME

    CibaseinfoId
    String ECustno
    String custno
    Long status

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥20 腾讯企业邮箱邮件可以恢复么
  • ¥15 有人知道怎么将自己的迁移策略布到edgecloudsim上使用吗?
  • ¥15 错误 LNK2001 无法解析的外部符号
  • ¥50 安装pyaudiokits失败
  • ¥15 计组这些题应该咋做呀
  • ¥60 更换迈创SOL6M4AE卡的时候,驱动要重新装才能使用,怎么解决?
  • ¥15 让node服务器有自动加载文件的功能
  • ¥15 jmeter脚本回放有的是对的有的是错的
  • ¥15 r语言蛋白组学相关问题
  • ¥15 Python时间序列如何拟合疏系数模型