簡體   English   中英

Rails-命名范圍

[英]Rails - Named scopes

對於我的用戶模型,我有:

class User < ActiveRecord::Base
  has_many :group_users, :class_name => "User", :finder_sql => 'select DISTINCT u.* from users u join permissions pp on pp.user_id=u.id join spaces p on pp.space_id=p.id where space_id in (select space_id from permissions pp2 where user_id=#{id}) and pp.user_id != #{id}'

我如何在如下范圍內訪問它:

  scope :usersInMySpaces, lambda { |user|
      group_users
  }

謝謝

你不能,沒有意義。 has_many關聯在許多情況下都像作用域一樣工作,但是在這種情況下,finder_sql太復雜了,無法與任何其他sql合並為作用域。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM