我有一个 Rails 应用程序,我试图根据子类的日期创建父类的列表。
现在我有:
orders = Order.where("order_reminders.date < ?", 1.month.from_now)
但我收到一个错误。
“没有这样的列:order_reminders.date”
我确信我的问题出在我的查询上,但我不知道如何解决它。
你需要使用类似的方法references
, joins
, includes
or eager_load
取决于你的需要。确定选择内容的最简单方法是转到文档/API http://api.rubyonrails.org/classes/ActiveRecord/QueryMethods.html#method-i-eager_load并阅读它们。
至于答案,如果order_reminders
被定义为一个关联Order
,只需使用joins
它使用一个INNER JOIN
默认情况下,这意味着它不会返回orders
没有order_reminders
当您搜索某些东西时,这很可能就是您想要的。
Order.joins(:order_reminders).where('order_reminders.date < ?', 1.month.from_now)
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)