Rails ActiveRecord返回相关表中id存在的记录

cti*_*y79 11 activerecord ruby-on-rails active-record-query

我有一个客户端模型和一个产品模型,其中客户端有许多产品,而产品属于CLient.

我需要找到一个只返回客户端的查询,如果他们在Product表中有记录

客户表

id |      name
--------------
 1 | Company A
 2 | Company B
 3 | Company C
Run Code Online (Sandbox Code Playgroud)

产品表

id |      name |  client_id
---------------------------
 1 | Product A |         1
 2 | Product B |         1
 3 | Product C |         3
 4 | Product D |         3
 5 | Product E |         1
Run Code Online (Sandbox Code Playgroud)

我只需要客户1 3

比如像

@clients = Client.where("client exists in products")  #something to this effect
Run Code Online (Sandbox Code Playgroud)

Val*_*von 19

最简单但不是最快的:

Client.where(:id => Product.select(:client_id).map(&:client_id))
Run Code Online (Sandbox Code Playgroud)

SQL子查询(更快):

Client.where("EXISTS(SELECT 1 from products where clients.id = products.client_id)")
Run Code Online (Sandbox Code Playgroud)


Eri*_*ton 7

这是另一种解决方案.这是像Valery的第二个解决方案的子查询,但没有写出sql:

Client.where(Product.where(client_id: Client.arel_table[:id]).exists)
Run Code Online (Sandbox Code Playgroud)


Eug*_*Zol 6

这是使用Where Exists gem 的解决方案(披露:我是它的作者):

Client.where_exists(:products)
Run Code Online (Sandbox Code Playgroud)