第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問(wèn)題,去搜搜看,總會(huì)有你想問(wèn)的

想要在Rails中查找沒(méi)有相關(guān)記錄的記錄

想要在Rails中查找沒(méi)有相關(guān)記錄的記錄

繁花如伊 2019-08-06 13:15:58
想要在Rails中查找沒(méi)有相關(guān)記錄的記錄考慮一個(gè)簡(jiǎn)單的關(guān)聯(lián)......class Person    has_many :friendsendclass Friend    belongs_to :personend讓所有在ARel和/或meta_where中沒(méi)有朋友的人最簡(jiǎn)潔的方法是什么?然后是一個(gè)has_many:通過(guò)版本class Person    has_many :contacts    has_many :friends, :through => :contacts, :uniq => trueendclass Friend    has_many :contacts    has_many :people, :through => :contacts, :uniq => trueendclass Contact    belongs_to :friend    belongs_to :personend我真的不想使用counter_cache - 而且我從我讀過(guò)的內(nèi)容中看起來(lái)并不適用于has_many:通過(guò)我不想拉出所有的person.friends記錄并在Ruby中循環(huán)它們 - 我希望有一個(gè)可以與meta_search gem一起使用的查詢/范圍我不介意查詢的性能成本而離實(shí)際SQL越遠(yuǎn)越好......
查看完整描述

3 回答

?
Qyouu

TA貢獻(xiàn)1786條經(jīng)驗(yàn) 獲得超11個(gè)贊

這仍然非常接近SQL,但它應(yīng)該讓所有人在第一種情況下沒(méi)有朋友:

Person.where('id NOT IN (SELECT DISTINCT(person_id) FROM friends)')


查看完整回答
反對(duì) 回復(fù) 2019-08-06
?
胡子哥哥

TA貢獻(xiàn)1825條經(jīng)驗(yàn) 獲得超6個(gè)贊

更好:

Person.includes(:friends).where( :friends => { :person_id => nil } )

對(duì)于hmt它基本上是一樣的,你依賴的事實(shí)是沒(méi)有朋友的人也沒(méi)有聯(lián)系人:

Person.includes(:contacts).where( :contacts => { :person_id => nil } )

更新

has_one在評(píng)論中有一個(gè)問(wèn)題,所以只是更新。這里的技巧是includes()期望關(guān)聯(lián)的名稱,但where期望表的名稱。對(duì)于一個(gè)has_one關(guān)聯(lián)通常會(huì)以單數(shù)表示,以便更改,但該where()部分保持不變。所以如果Person只有has_one :contact你的陳述是:

Person.includes(:contact).where( :contacts => { :person_id => nil } )

更新2

有人詢問(wèn)反向,沒(méi)有人的朋友。正如我在下面評(píng)論的那樣,這實(shí)際上讓我意識(shí)到最后一個(gè)字段(上面的:person_id:)實(shí)際上并不需要與你返回的模型相關(guān),它只需要是連接表中的一個(gè)字段。他們都將是nil如此,它可以是任何一個(gè)。這導(dǎo)致了上述更簡(jiǎn)單的解決方案:

Person.includes(:contacts).where( :contacts => { :id => nil } )

然后切換這個(gè)以返回沒(méi)有人的朋友變得更簡(jiǎn)單,你只改變前面的班級(jí):

Friend.includes(:contacts).where( :contacts => { :id => nil } )

更新3 - Rails 5

感謝@Anson提供優(yōu)秀的Rails 5解決方案(下面給出他的答案為+ 1),您可以使用left_outer_joins以避免加載關(guān)聯(lián):

Person.left_outer_joins(:contacts).where( contacts: { id: nil } )

我把它包括在這里,所以人們會(huì)找到它,但他應(yīng)該得到+ 1s。太棒了!


查看完整回答
反對(duì) 回復(fù) 2019-08-06
?
鳳凰求蠱

TA貢獻(xiàn)1825條經(jīng)驗(yàn) 獲得超4個(gè)贊

smathy有一個(gè)很好的Rails 3答案。

對(duì)于Rails 5,您可以使用left_outer_joins以避免加載關(guān)聯(lián)。

Person.left_outer_joins(:contacts).where( contacts: { id: nil } )

查看api文檔。它是在拉取請(qǐng)求#12071中引入的。


查看完整回答
反對(duì) 回復(fù) 2019-08-06
  • 3 回答
  • 0 關(guān)注
  • 730 瀏覽

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)