- xml - AJAX/Jquery XML 解析
- 具有多重继承的 XML 模式
- .net - 枚举序列化 Json 与 XML
- XML 简单类型、简单内容、复杂类型、复杂内容
设置:Rails 3.2.18、Postgres
我有两个对象,例如,将它们称为 Author
和 Article
,具有以下设置:
class Author
has_many :articles
...
end
class Article
belongs_to :author
class << self
def published_over_one_year_ago
where(arel_table[:published_at].lt(1.year.ago))
end
end
end
我正在尝试查找所有 Author
记录,其中 所有 相关的 Article
记录都是在一年前发布的。这段代码:
Author.joins(:article).merge(Article.published_over_one_year_ago)
... 返回 Author
对象,其中 至少一个 关联的 Article
是在一年多以前发表的,但我只需要 作者
记录,其中所有 关联的文章
记录都超过一年。使用 arel/ActiveRecord 是否可行,还是我必须使用原始 SQL?
可能“有效”的 SQL 解决方案:
query = ERB.new(<<-SQL_END).result(binding)
'author'.id in (
select art.author_id
from articles art
group by art.author_id
having sum(case (art.published_at::date >= current_date) when true then 1 else 0 end) = 0 AND
sum(case(art.published_at::date < current_date) when true then 1 else 0 end) > 0
)
SQL_END
# The following now appears to do what I want it to do.
Author.includes(:articles).where(query)
更新 我看到已经有一个使用 arel 的建议答案,这非常出色。如果可能的话,有人建议直接使用 ActiveRecord 吗?
最佳答案
使用 Arel 和公用表表达式:
articles = Article.arel_table
authors = Author.arel_table
cte_table = Arel::Table.new(:cte_table)
composed_cte =
Arel::Nodes::As.new(cte_table,
articles.project(articles[:author_id],
articles[:published_at].maximum.as("max_published_at"))
.group(articles[:author_id])
)
然后:
authors
.join(cte_table).on(cte_table[:author_id].eq(authors[:id]))
.with(composed_cte)
.where(cte_table[:max_published_at].lt(1.year.ago))
.project(authors[:id])
.to_sql
返回(为清楚起见格式化):
WITH "cte_table" AS (
SELECT articles.author_id,
MAX(articles.published_at) AS max_published_at
FROM articles
GROUP BY articles.author_id
)
SELECT authors.id
FROM authors
INNER JOIN cte_table
ON cte_table.author_id = authors.id
WHERE cte_tble.max_published_at < '2014-01-25 23:04:16.532796'
使用它:
来自
[2] test» Article.pluck(:author_id, :published_at)
D, [2015-01-26T00:10:06.763197 #21897] DEBUG -- : (0.6ms) SELECT "articles"."author_id", "articles"."published_at" FROM "articles"
=> [
[0] [
[0] 1,
[1] Sun, 25 Jan 2015 23:31:58 UTC +00:00
],
[1] [
[0] 1,
[1] Fri, 01 Jan 1999 00:00:00 UTC +00:00
],
[2] [
[0] 2,
[1] Fri, 01 Jan 1999 00:00:00 UTC +00:00
]
查询返回:
[2015-01-26T00:10:25.279587 #21897] DEBUG -- : (0.9ms) WITH "cte_table" AS (SELECT "articles"."author_id", MAX("articles"."published_at") AS max_published_at FROM "articles" GROUP BY "articles"."author_id") SELECT "authors"."id" FROM "authors" INNER JOIN "cte_table" ON "cte_table"."author_id" = "authors"."id" WHERE "cte_table"."max_published_at" < '2014-01-25 23:10:25.277902'
=> [
[0] {
"id" => "2"
}
]
编辑
不使用 Arel:
Author.joins(:articles)
.where("authors.id != ANY (?)",
Article.select('author_id')
.where("published_at > ?", 1.year.ago)
)
如果将 .published_last_year
添加到 Article 中:
class Article < ActiveRecord::Base
belongs_to :author
def self.published_last_year
where("published_at > ?", 1.year.ago)
end
end
然后
Author.joins(:articles)
.where("authors.id != ANY (?)",
Article.published_last_year.select('author_id'))
Rails4版本
Author.joins(:articles)
.where.not(id: Article.published_last_year.select('author_id'))
关于ruby-on-rails - rails : Return only objects where all associations meet a condition,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28142264/
我遵循了一本名为“Sitepoint Full Stack Javascript with MEAN”的书中的教程,我刚刚完成了第 6 章,应该已经创建了一个带有“数据库”的“服务器”。数据库只不过是
在 Jquery 中,我创建两个数组,一个嵌入另一个数组,就像这样...... arrayOne = [{name:'a',value:1}, {name:'b',value:2}] var arra
这个问题在这里已经有了答案: What is the explanation for these bizarre JavaScript behaviours mentioned in the 'Wa
我被放在别人的代码上,有一个类用作其他组件的基础。当我尝试 ng serve --aot(或 build --prod)时,我得到以下信息。 @Component({ ...,
我正在测试一些代码,并使用数据创建了一个 json 文件。 问题是我在警报中收到“[object Object],[object Object]”。没有数据。 我做错了什么? 这是代码:
我想打印 [object Object],[object Object] 以明智地 "[[{ 'x': '1', 'y': '0' }, { 'x': '2', 'y': '1' }]]"; 在 ja
我有一个功能 View ,我正在尝试以特殊格式的方式输出。但我无法让列表功能正常工作。 我得到的唯一返回是[object Object][object Object] [object Object]
在使用优秀的 Sim.js 和 Three.js 库处理 WebGL 项目时,我偶然发现了下一个问题: 一路走来,它使用了 THREE.Ray 的下一个构造函数: var ray = new THRE
我正在使用 Material UI 进行多重选择。这是我的代码。 {listStates.map(col => (
我的代码使用ajax: $("#keyword").keyup(function() { var keyword = $("#keyword").val(); if (keyword.
我遇到了下一个错误,无法理解如何解决它。 Can't resolve all parameters for AuthenticationService: ([object Object], ?, [o
我正在尝试创建一个显示动态复选框的表单,至少应选中其中一个才能继续。我还需要获取一组选中的复选框。 这是组件的代码: import { Component, OnInit } from '@angul
我正在开发 NodeJs 应用程序,它是博客应用程序。我使用了快速验证器,我尝试在 UI 端使用快速闪存消息将帖子保存在数据库中之前使用闪存消息验证数据,我成功地将数据保存在数据库中,但在提交表单后消
我知道有些人问了同样的问题并得到了解答。我已经查看了所有这些,但仍然无法解决我的问题。我有一个 jquery snipet,它将值发送到处理程序,处理程序处理来自 JS 的值并将数据作为 JSON 数
我继承了一个非常草率的项目,我的任务是解释为什么它不好。我注意到他们在整个代码中都进行了这样的比较 (IQueryable).FirstOrDefault(x => x.Facility == fac
我只是在删除数组中的对象时偶然发现了这一点。 代码如下: friends = []; friends.push( { a: 'Nexus', b: 'Muffi
这两个代码片段有什么区别: object = nil; [object release] 对比 [object release]; object = nil; 哪个是最佳实践? 最佳答案 object
我应该为其他人将从中继承的第一个父对象传递哪个参数,哪个参数更有效 Object.create(Object.prototype) Object.create(Object) Object.creat
我在不同的对象上安排不同的选择器 [self performSelector:@selector(doSmth) withObject:objectA afterDelay:1]; [self per
NSLog(@"%p", &object); 和 NSLog(@"%p", object); 有什么区别? 两者似乎都打印出一个内存地址,但我不确定哪个是对象的实际内存地址。 最佳答案 这就是我喜欢的
我是一名优秀的程序员,十分优秀!