Grails:使用Criteria + projection的结果作为原始表的过滤器

时间:2013-02-23 14:46:15

标签: grails hibernate-criteria createcriteria

我有以下表/型号:

class Post {
  int id;
  String comment;
  static belongsTo = [category_id:Category];
}

我希望创建一个可以按Post过滤掉最后id(最高Category)的查询。我希望结果为List<Post>形式。

换句话说(我相信)在SQL中,查询看起来如下:

SELECT *
FROM
  Post AS source
  JOIN (
    SELECT MAX(id) AS id, category_id 
    FROM Post
    GROUP BY category_id
  ) AS filter
  ON source.id = filter.id;

如果我理解正确,第一步是使用HibernateCriteriaBuilder

def c = Post.createCriteria();
  def results = c.list {
    projections {
      groupProperty("category_id", "myid")
      max("id", "version")
    }
  }

所以我的问题分为两部分:

  1. 我是在正确的轨道上吗?
  2. 如何使用结果对象获取List<Post>数组?

    (类似于:def latest = Post.FindAllByXXX(result);

1 个答案:

答案 0 :(得分:6)

是的,你走在正确的轨道上。我还要将Post的 id 属性添加到我的投影中:

projections {
    property('id')
}

然后使用 id 收集所有帖子以获取帖子列表,例如:

def latestPosts = results?.collect{Post.read(it[0])}