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 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 对于相关问题的求解与代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 信号傅里叶变换在matlab上遇到的小问题请求帮助
  • ¥15 保护模式-系统加载-段寄存器
  • ¥15 电脑桌面设定一个区域禁止鼠标操作
  • ¥15 求NPF226060磁芯的详细资料