使用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
可否全部写成可为空的字段?

使用hql查询,为什么一行数据中其中一个字段的值为空,那么返回的list包含的对象就是null!
- 写回答
- 好问题 0 提建议
- 关注问题
- 邀请回答
-
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 NAMECibaseinfoId
String ECustno
String custno
Long status本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报