簡體   English   中英

通過HABTM關聯屬性查詢模型

[英]Querying model by attribute of HABTM association

我在用戶和對話這兩個模型之間有一個 HABTM 關聯。 我希望能夠查詢登錄用戶的對話( current_user.conversations ),將另一個用戶的 id 傳遞給它,並讓它返回一個由兩個用戶共享的對話(如果存在)。 (一個額外的好處是讓查詢在不存在的情況下創建一個。)

關聯工作正常,因此我可以通過@user.conversations@conversation.users等實例變量訪問關聯對象,因此我可以走很長的路,遍歷每個對話對象並搜索每個對象中的用戶關聯。 .. 但是必須有一種有效的方法來構造這個查詢。 我希望能夠做的是類似current_user.conversations.where(conversation.users.exists?(id: @user_id))或類似Conversation.find(users: {id: @user_id AND current_user.id})

我想對此有一個明顯的答案,我一直在這里尋找類似的問題,但沒有找到。 在瀏覽了 Rails API 文檔后,我想我正在尋找的解決方案以某種方式涉及.includes() ,但我無法讓它工作。

有什么建議嗎? 謝謝。

假設你有兩個用戶@sender@receiver ,並有一個(或可能更多),他們之間的對話。 查詢他們共享對話的一種可能方法是使用 ActiveRecord 中的merge功能。 merge將選擇它們之間對話的交集:

@shared_conversations = @sender.conversations.merge(@receiver.conversations)

請注意,結果將是一個集合,而不是單個對話。 在 SQL 中,這將轉換為INNER JOIN

如果您想修改此查詢以創建不存在的對話,則可以使用first_or_create 顧名思義, first_or_create返回集合中的第一項。 如果集合為空,它將創建一個新對象。 您可以向它傳遞一個塊以進一步控制新創建的對象:

@shared_conversations = @sender.conversations.merge(@receiver.conversations).first_or_create do |conversation|
  conversation.title = "#{@sender.first_name}'s conversation"
end

您可以在 Rails 文檔中找到有關merge更多詳細信息: http : //apidock.com/rails/ActiveRecord/SpawnMethods/merge

嘗試 current_user.conversations.includes(:users).where(user.id:current_user.id)

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM