Viele zu vielen Beziehungen, Schienen
-
30-09-2019 - |
Frage
Ich habe eine viel zu viele Beziehung zwischen Benutzern und den von ihnen abonnierten Kanälen. Wenn ich jedoch meine Modellabhängigkeit zwischen Benutzer- und Benutzerkanälen oder -kanälen und Benutzerkanal betrachte, besteht stattdessen eine direkte Verbindung zwischen Benutzern und Kanälen. Wie bringe ich Benutzerkanäle zwischen zwei? Benutzermodell
class User < ActiveRecord::Base
acts_as_authentic
ROLES = %w[admin moderator subscriber]
has_and_belongs_to_many :channels
has_many :channel_mods
named_scope :with_role, lambda { |role| {:conditions => "roles_mask & #{2**ROLES.index(role.to_s)} > 0 "} }
def roles
ROLES.reject { |r| ((roles_mask || 0) & 2**ROLES.index(r)).zero? }
end
def roles=(roles)
self.roles_mask = (roles & ROLES).map { |r| 2**ROLES.index(r) }.sum
end
def role_symbols
role.map do |role|
role.name.underscore.to_sym
end
end
end
Kanalmodell
class Channel < ActiveRecord::Base
acts_as_taggable
acts_as_taggable_on :tags
has_many :messages
has_many :channel_mods
has_and_belongs_to_many :users
end
UserSchannel -Modell
class UsersChannels < ActiveRecord::Base
end
Lösung
Siehe das Has_Many: Durch Dokumentation Auf den Rails Guides, die Sie durch die Konfiguration a leitet has_many
Beziehung zu einem intervenierenden Modell.
Andere Tipps
Die HABTM -Beziehung generiert die UserSchannels automatisch - wenn Sie zum Beispiel auf das Modell für die Link -Tabelle zugreifen möchten (fügen Sie ihm einige weitere Attribute hinzu - time_channel_watched oder was auch immer), müssen Sie die Modelle ändern (und explizit definieren und migrieren Ein UserSchannel -Modell mit der Attribute -ID: primär_key, user_id: Integer, Channel_ID: Integer) zu:
class Channel < ActiveRecord::Base
has_many :users_channels, :dependent => :destroy
has_many :users, :through => :users_channels
end
class User < ActiveRecord::Base
has_many :users_channels, :dependent => :destroy
has_many :channels, :through => :users_channels
end
class UsersChannels < ActiveRecord::Base
belongs_to :user
belongs_to :channel
end
Hinweis: Da Sie Ihr eigenes Linkmodell definieren, müssen Sie nicht beim HABTM -definierten Tabellennamen von UserSchannels bleiben - Sie können den Modellnamen in so etwas wie "Uhren" ändern. All das ist so ziemlich im Rails Guide, der erwähnt wurde.