Kohana ORM,重写 ORDER BY 和 GROUP BY 查询
我需要从使用 Kohana ORM 在article.id = message.article_id 上加入的相关表中获取按最新评论排序的文章列表。我设法构建了一个查询,该查询是 GROUPS 然后是 ORDERS:
SELECT *
FROM `articles`
LEFT JOIN `comments` ON ( `articles`.`id` = `comments`.`article_id` )
GROUP BY `comments`.`item_id`
ORDER BY `datetime` DESC
我试图构建的查询是:
SELECT * FROM `articles` LEFT JOIN
(SELECT article_id, MAX(datetime) as datetime FROM comments GROUP BY (article_id))
AS b ON `articles`.`id` = b.`article_id`
ORDER BY datetime
我不知道如何将其重写为 Kohana ORM...(而且我无法避免 ORM,因为有大量的依赖于它的代码)
I need to get a list of Articles sorted by the latest Comment from a related table joined on article.id = message.article_id using Kohana ORM. I managed to build a query that GROUPS and only then ORDERS:
SELECT *
FROM `articles`
LEFT JOIN `comments` ON ( `articles`.`id` = `comments`.`article_id` )
GROUP BY `comments`.`item_id`
ORDER BY `datetime` DESC
The query I am trying to build is:
SELECT * FROM `articles` LEFT JOIN
(SELECT article_id, MAX(datetime) as datetime FROM comments GROUP BY (article_id))
AS b ON `articles`.`id` = b.`article_id`
ORDER BY datetime
I have no idea how to rewrite it into Kohana ORM... (and I can't avoid ORM because there is a ton of code that depends on it)
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
这是您的查询的翻译,我不确定它是否有效
This is the translation of your query, I'm not really sure if it will work
这会生成 sql 如下:
与您的第一个查询匹配。
我不确定如何在 ORM 中使用嵌套查询,但有 查询生成器在 kohana 中,这应该可以帮助你。
This generates sql as :
which matches your first query.
I'm not sure how to use nested query in ORM but there is Query builder in kohana which should do the trick for you.