我只想从表中获取一些列值。因此,我已经使用投影来实现这一目标。该代码有效,但我认为它无效。
我的问题是当我使用ProjectionsList并将标准条件列表设置为ArrayList时-Bulletin对象为null。我不确定如何更好地解释这一点。因此,我将放置代码,然后请阅读以下内容:
List<Bulletin> list = new ArrayList<Bulletin>();
BulletinList bulletinList = null;
Criteria criteria = null;
criteria = this.getSession().createCriteria(Bulletin.class)
.setProjection(Projections.projectionList()
.add(Projections.property(bulletinIdAttr))
.add(Projections.property(docNameAttr))
.add(Projections.property(docTypeCodeAttr))
);
criteria.addOrder(Order.desc(createdTimeAttr));
List<Object> rows = criteria.list();
for (Object r : rows) {
Object[] row = (Object[]) r;
Bulletin bull = new Bulletin();
bull.setBulletinId((Long) row[0]);
bull.setDocumentName((String) row[1]);
bull.setDocumentTypeCode((String) row[2]);
list.add(bull);
}
bulletinList = new BulletinList();
bulletinList.setBulletins(list);
return bulletinList;
我只需要将criteria.list设置为BulletinList(持有Bulletin对象列表的类)。但是,当我使用投影时,公告对象为null。
我也在阅读另一个要使用的线程
setResultTransformer(Transformers.aliasToBean
但这也不起作用。因此,有人可以在此方面提供帮助,以使代码变得更好。
谢谢
ish
最佳答案
Projections.property()
以字符串作为参数。在您提供的代码中,该String的值应为Bulletin类的成员的名称。例如,大概bulletinIdAttr
是具有这样一个值的String,否则您将遇到运行时错误。 setProjection
时,您隐式将ResultTransformer设置为PROJECTIONS
,这就是您想要的。无需自己调用setResultTransformer
。我会像这样简化程序List<Object[]> rows = criteria.list();
for (Object[] row : rows) {
Bulletin bull = new Bulletin();
bull.setBulletinId((Long) row[0]);
bull.setDocumentName((String) row[1]);
bull.setDocumentTypeCode((String) row[2]);
list.add(bull);
}
但这不应该对您的结果产生任何影响。您是否已检查
rows
为空?关于hibernate - hibernate 投影列表,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/11057189/