[英]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.