首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Rails where.not跳过一些记录

Rails where.not跳过一些记录
EN

Stack Overflow用户
提问于 2015-10-18 16:30:29
回答 3查看 42关注 0票数 0

除了20,21,22类视频外,我试着获取所有视频。

这是我的查询

代码语言:javascript
复制
@cc = Video.joins(:categories).where.not(categories: { id: [20,21,22]})

但是当我做@cc.find(113).categories的时候我得到了这个

代码语言:javascript
复制
#<ActiveRecord::Associations::CollectionProxy 
[#<Category id: 21, title: "music">, #<Category id: 22, title: "movies">,
#<Category id: 28, title: "collage">]>

我做错了什么?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2015-10-18 17:10:11

您正在执行错误的查询。试着:

代码语言:javascript
复制
Video.where.not(id: Video.joins(:categories).where(categories: { id: [20,21,22]}).pluck(:id))
票数 0
EN

Stack Overflow用户

发布于 2015-10-18 16:35:22

试试这个:

代码语言:javascript
复制
array = [21,22,23]
@cc = Video.joins(:categories).where("category.id not in (?)", array)

编辑

我想我发现了问题所在。假设您的Video模型与Category处于has_many关系中。所以你应该做:

代码语言:javascript
复制
class Video < ActiveRecord::Base
  has_many :categories
  has_many :excluded, -> (array) { where("id not in (?)", array) }, class_name: 'Category'
end

你这样称呼它:

代码语言:javascript
复制
Video.find(113).excluded([21,22,23])
票数 1
EN

Stack Overflow用户

发布于 2015-10-18 16:42:24

尝尝这个,

代码语言:javascript
复制
@cc = Video.includes(:categories).references(:categories).where.not(categories: { id: [20,21,22]})

参考,https://robots.thoughtbot.com/activerecords-wherenot

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/33200349

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档