我有User模型,has_many技能。我需要让用户匹配所有选定的技能。例如:
User A: Ruby, HTML, JavaScript.
User B: Ruby
User C: Ruby, C++当我使用技能名称或ids列表进行搜索时。我需要get用户在这个列表中拥有所有的值。所以,使用Ruby & Javascript搜索,我需要得到User A。
如果我使用洗劫宝石 skills_id_in,它将返回所有具有Ruby技能的用户。查询如下:
SELECT \"users\".* FROM \"users\" LEFT OUTER JOIN \"user_skills\" ON \"user_skills\".\"user_id\" = \"users\".\"id\" LEFT OUTER JOIN \"skills\" ON \"skills\".\"id\" = \"user_skills\".\"skill_id\" WHERE \"skills\".\"id\" IN (1, 3)如果在洗劫中不允许的话。您能帮助如何在ActiveRecord中实现&在DB级别中运行吗?
我的观点:它不能实现使用洗劫机,如果您知道本地查询匹配所有关联,让我知道?
发布于 2017-01-16 00:45:36
我似乎无法找到一种直接通过Postgres查询a包含的方法,但下面的方法会奏效:
result = User.joins(:skills)
skills_names = ['Ruby', 'JavaScript']
skills_names.each do |skill_name|
result = result.where('? = ANY(name)', skill_name)
end如果您知道您将提前查询多少技能,则可以将它们合并到一个查询中:
User.joins(:skills).where('? = ANY(name) AND ? = ANY(name)', 'Ruby', 'JavaScript')https://stackoverflow.com/questions/41660079
复制相似问题