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

使用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

    已采纳该答案
    打赏 评论
  • wanghaolovezlq 2009-04-21 10:13

    你打开sql显示开关

    hibernate.show_sql true

    看控制台打印出来的sql语句是怎么样的先

    打赏 评论
  • wanghaolovezlq 2009-04-21 11:36

    全部写成可为空的字段那就没办法了吧

    打赏 评论

相关推荐 更多相似问题