我有以下表/型号:
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);
)
答案 0 :(得分:6)
是的,你走在正确的轨道上。我还要将Post的 id 属性添加到我的投影中:
projections {
property('id')
}
然后使用 id 收集所有帖子以获取帖子列表,例如:
def latestPosts = results?.collect{Post.read(it[0])}