Rails habtm and finding record with no association

前端 未结 2 888
囚心锁ツ
囚心锁ツ 2020-12-14 21:39

I have 2 models:

class User < ActiveRecord::Base
    has_and_belongs_to_many :groups
end

class Group < ActiveRe         


        
相关标签:
2条回答
  • 2020-12-14 21:57

    Your implicit join table would have been named groups_users based on naming conventions. Confirm it once in your db. Assuming it is:

    In newer Rails version:

    scope :not_in_any_group, -> {
        joins("LEFT JOIN groups_users ON users.id = groups_users.user_id")
        .where("groups_users.user_id IS NULL")
    }
    

    For older Rails versions:

    scope :not_in_any_group, {
        :joins      => "LEFT JOIN groups_users ON users.id = groups_users.user_id",
        :conditions => "groups_users.user_id IS NULL",
        :select     => "DISTINCT users.*"
    }
    
    0 讨论(0)
  • 2020-12-14 22:11

    If you convert from HABTM to has_many through (more flexible) association, then you can use something like this:

    class Group < ActiveRecord::Base
      has_many :groups_users, dependent: :destroy
      has_many :users, through: :groups_users, uniq: true
    
      scope :in_groups, -> { includes(:groups_users).where(groups_users: {group_id: nil}) }
    end
    
    class User < ActiveRecord::Base
      has_many :groups_users, dependent: :destroy
      has_many :groups, through: :groups_users
    end
    
    class GroupsUser < ActiveRecord::Base
      belongs_to :group
      belongs_to :user
    end
    
    0 讨论(0)
提交回复
热议问题