我只想从表中获取一些列值。因此,我已经使用投影来实现这一目标。该代码有效,但我认为它无效。

我的问题是当我使用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,否则您将遇到运行时错误。
  • 在Criteria实例上调用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/

    10-08 20:41