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

你这种配置和代码应该是用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

你打开sql显示开关

hibernate.show_sql true

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

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