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)
这是另一种解决方案.这是像Valery的第二个解决方案的子查询,但没有写出sql:
Client.where(Product.where(client_id: Client.arel_table[:id]).exists)
Run Code Online (Sandbox Code Playgroud)
这是使用Where Exists gem 的解决方案(披露:我是它的作者):
Client.where_exists(:products)
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
6318 次 |
| 最近记录: |