我有下表/模型:
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")
}
}
所以我的问题分为两部分:
我在正确的轨道上吗?
如何使用结果对象获取
List<Post>
数组?(有点像
def latest = Post.FindAllByXXX(result);
:)