2

我有下表/模型:

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

我希望创建一个可以过滤Postid每个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);:)

4

1 回答 1

6

是的,你在正确的轨道上。我还将 Post 的id属性添加到我的预测中:

projections {
    property('id')
}

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

def latestPosts = results?.collect{Post.read(it[0])}
于 2013-02-24T10:36:46.583 回答