Отношения многие ко многим, рельсы

У меня есть отношение «многие ко многим» между пользователями и каналами, на которые они подписаны. Но когда я смотрю на зависимость моей модели между пользователем и пользовательскими каналами или каналами и пользовательским каналом, вместо этого возникает прямая связь между пользователями и каналами. как разместить каналы пользователей между двумя? Модель пользователя

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

Модель канала

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

class UsersChannels < ActiveRecord::Base
end

person Antarr Byrd    schedule 02.12.2010    source источник


Ответы (2)


См. has_many :through в руководствах по Rails, которые помогут вам путем настройки отношения has_many с промежуточной моделью.

person Lee Jarvis    schedule 02.12.2010
comment
Спасибо, не могли бы вы указать мне где-нибудь, где показано, как создавать эти соединения с использованием контроллеров и представлений? - person Antarr Byrd; 02.12.2010

Отношения HABTM автоматически волшебным образом генерируют UsersChannels — если вы хотите получить доступ к модели для таблицы ссылок (например, добавить к ней еще несколько атрибутов — time_channel_watched или что-то еще), вам придется изменить модели (и явно определить и перенести модель UsersChannel с атрибутами id:primary_key, user_id:integer, channel_id:integer) до:

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

Примечание: поскольку вы определяете свою собственную модель ссылок, вам не нужно оставаться с определенным HABTM именем таблицы UsersChannels — вы можете изменить имя модели на что-то вроде «Watches». Все вышеперечисленное в значительной степени находится в упомянутом руководстве по Rails.

person Pasted    schedule 03.12.2010
comment
используйте hmt вместо habtm. Лучшая практика. - person Michael Durrant; 27.09.2011