j'ai 4 modèles, Message, groupe, utilisateur, membresrails has_many - trop de requêtes
class Group < ActiveRecord::Base
has_many :memberships
has_many :users, :through => :memberships
has_many :groups_messages
has_many :messages, :through => :groups_messages, :order => "created_at desc"
named_scope :with_memberships, :include => :memberships
end
class Membership < ActiveRecord::Base
belongs_to :user
belongs_to :group
end
class User < ActiveRecord::Base
has_many :memberships
has_many :groups, :through => :memberships
end
class Message < ActiveRecord::Base
has_and_belongs_to_many :recipients, :class_name => "User"
has_many :groups_messages
has_many :groups, :through => :groups_messages
def accessible
self.groups.with_memberships.map(&:user_ids).include?(User.current.id)
end
end
message peut être affiché à un groupe, et si l'utilisateur actuel est membre du groupe, il a un droit de le lire.
Je suis en train de vérifier si l'utilisateur est un membre du groupe avec Message.accessible, mais il produit une requête à beaucoup:
Group Load (0.1ms) SELECT `groups`.* FROM `groups` INNER JOIN `groups_messages` ON `groups`.id = `groups_messages`.group_id WHERE ((`groups_messages`.message_id = 381)) AND ((`groups_messages`.message_id = 381))
Membership Load (0.1ms) SELECT `memberships`.* FROM `memberships` WHERE (`memberships`.group_id = 1)
User Load (0.1ms) SELECT `users`.id FROM `users` INNER JOIN `memberships` ON `users`.id = `memberships`.user_id WHERE ((`memberships`.group_id = 1))
Je ne ai pas besoin utilisateur requête de charge - user_id est contenue dans L'adhésion, donc la dernière requête est inutile.
J'ai essayé de changer la méthode accessible à
def accessible
self.groups.with_memberships.exists?(:user_id=>User.current.id)
end
Mais il essaie d'utiliser user_id dans la requête de charge du groupe et bien sûr échoue. Comment puis-je me débarrasser de la dernière requête? Rails 2.3.2
'has_many: requêtes' –