我有一个users
表和一个blocked_users
表。 users
包含我的所有身份验证数据,网站首选项等,而blocked_users
包含source_id
和target_id
。
我想返回一个用户未阻止但尚未阻止当前用户的所有用户的集合。
现在我有以下代码,我通过调用@user.available_users
执行它,但它执行三个查询。有没有办法让这个单一的查询?
class User < Sequel::Model
one_to_many :blocked_users, :key=>:source_id
one_to_many :blocked_by_users, :key=>:target_id, :class => BlockedUser
def block_user(id)
BlockedUser.create({source_id:self.id, target_id:id})
end
def blocked_user_ids
self.blocked_users.map{|bu| bu[:target_id]}
end
def blocked_by_user_ids
self.blocked_by_users.map{|bu| bu[:target_id]}
end
def available_users
User.exclude(:id=>self.blocked_users.map{|bu| bu[:target_id]}).exclude(:id=>self.blocked_by_users.map{|bu| bu[:target_id]})
end
end
我在我的User类中添加了以下方法:
def test_avail
User.exclude(:blocked_users=>self).exclude(:blocked_by_users=>self)
end
1.9.3p0 :001 > User.all.first.test_avail
INFO - (0.000732s) SELECT * FROM `users`
Sequel::Error: invalid association class User for association :blocked_users used in dataset filter for model User, expected class BlockedUser
答案 0 :(得分:2)
使用过滤器关联支持可能是最简单的:
def available_users
User.exclude(:blocked_users=>self).exclude(:blocked_by_users=>self)
end