gpt4 book ai didi

ruby-on-rails - 帮助理解多态关联(rails)

转载 作者:行者123 更新时间:2023-12-04 03:46:10 24 4
gpt4 key购买 nike

我知道这方面有很多资源,但我很难将它们中的任何一个与我的情况联系起来,所以我希望有人能帮助我阐明它是如何工作的:

基本上我有一个模型 Action,(每当一个用户做一些影响另一个用户的事情时创建它,例如评论他们的文章或对某人的照片投票),这些 Action 将是在用户仪表板页面中列出与他们相关的所有已发生的操作,就像流...有点像 Github 的“新闻提要”

Github's "News Feed"

我决定创建一个多态关联,这是我的模型的样子:

class Action < ActiveRecord::Base
belongs_to :instigator, :polymorphic => true
belongs_to :victim, :polymorphic => true
end

我使用了煽动者和受害者,因为任何人都可以创建这些行为,而这些行为又总是会影响另一个用户,这是我的用户模型

class User < ActiveRecord::Base
has_many :actions, :as => :instigator
has_many :actions, :as => :victim
end

这就是我认为我出错的地方,因为最终我想要一个查询,当我运行类似User.find(1).actions 实际返回用户既是煽动者又是受害者的所有实例,我想我不能同时拥有这两个have_many 就在那里,因为像这样使用时我只会得到用户是 victim 的实例。

这是我的迁移:

create_table :actions do |t|
t.references :instigator, :polymorphic => true
t.references :victim, :polymorphic => true
t.string :action_performed
t.references :resource, :polymorphic => true
t.timestamps
end

感谢您的帮助,我总是喜欢 SO 社区提供的重要建议和帮助。

最佳答案

这让人想起经典的友谊模型问题。多态关联不是重点。

Rails 版本无关的解决方案:

class User < ActiveRecord::Base
has_many :instigator_actions, :class_name => "Action", :as => :instigator
has_many :victim_actions, :class_name => "Action", :as => :victim
has_many :actions, :finder_sql => '
SELECT a.*
FROM actions a
WHERE (a.instigator_type = "User" AND instigator_id = #{id}) OR
(a.victim_type = "User" AND victim_id = #{id})'
end

在创建操作时使用前两个关联之一创建它们。

u1.instigator_actions.create(:victim => u2)

u1.victim_actions.create(:instigator => u2)

同时,您可以使用 actions 关联获取与用户关联的操作列表。

u1.actions

关于ruby-on-rails - 帮助理解多态关联(rails),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3648831/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com