首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >查找其关联依次为零关联的所有记录。

查找其关联依次为零关联的所有记录。
EN

Stack Overflow用户
提问于 2018-01-31 17:38:55
回答 3查看 97关注 0票数 3

鉴于以下模式:

代码语言:javascript
复制
class Score < ApplicationRecord
  belongs_to :composition
end

class Composition < ApplicationRecord
  has_many :scores
  has_one :invoice, dependent: :destroy
end

class Invoice < ApplicationRecord
  belongs_to :composition
end

找到分数的最佳方法是什么,它的组成有一张发票

我试过:

代码语言:javascript
复制
Score.joins(:composition).where(composition: {invoice: nil})
代码语言:javascript
复制
csn = Composition.includes(:invoice).where(invoices:{id:nil})
Score.where(csn.include? composition)
Score.where(csn.map(&:id).include? composition_id)
代码语言:javascript
复制
Score.where(Composition.left_outer_joins(:invoice).where(invoices:{id:nil}).includes? composition)

都有错误。有什么想法吗?

编辑:这里是与schema.rb对应的表

代码语言:javascript
复制
  create_table "compositions", force: :cascade do |t|
    ...
  end

  create_table "invoices", force: :cascade do |t|
    t.integer  "composition_id"
    ...
    t.index ["composition_id"], name: "index_invoices_on_composition_id", using: :btree
  end

  create_table "scores", force: :cascade do |t|
    t.integer  "composition_id",                           null: false
    ...
  end
EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2018-01-31 17:58:17

请尝试以下查询:

代码语言:javascript
复制
Score.joins(:composition).includes(composition: : invoice).where(invoices: { id: nil })
票数 1
EN

Stack Overflow用户

发布于 2018-01-31 17:53:23

试着跟随

代码语言:javascript
复制
Score.joins(:composition).where('compositions.invoice_id IS NULL')

上面应该管用,祝你好运!

票数 0
EN

Stack Overflow用户

发布于 2018-01-31 19:55:34

请尝试以下查询,

代码语言:javascript
复制
Score.joins(:composition).where('compositions.id NOT IN (?)', Invoice.pluck(:composition_id))

如果这不起作用,那么让我知道compositions表和scores表中的列

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

https://stackoverflow.com/questions/48548273

复制
相关文章

相似问题

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