首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Rails ActiveRecord返回相关表中id存在的记录

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

Stack Overflow用户
提问于 2013-01-07 09:54:57
回答 4查看 7.2K关注 0票数 13

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

我需要查找一个查询,该查询仅返回在Product表中有记录的客户端

客户端表

代码语言:javascript
运行
复制
id |      name
--------------
 1 | Company A
 2 | Company B
 3 | Company C

products表

代码语言:javascript
运行
复制
id |      name |  client_id
---------------------------
 1 | Product A |         1
 2 | Product B |         1
 3 | Product C |         3
 4 | Product D |         3
 5 | Product E |         1

我只需要客户1 3

例如,类似于

代码语言:javascript
运行
复制
@clients = Client.where("client exists in products")  #something to this effect
EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2013-01-07 14:13:55

最简单但不是最快的:

代码语言:javascript
运行
复制
Client.where(:id => Product.select(:client_id).map(&:client_id))

SQL子查询(更快):

代码语言:javascript
运行
复制
Client.where("EXISTS(SELECT 1 from products where clients.id = products.client_id)")
票数 23
EN

Stack Overflow用户

发布于 2015-07-29 02:34:20

这里有另一个解决方案。它是一个子查询,类似于Valery的第二个解决方案,但没有写出sql:

代码语言:javascript
运行
复制
Client.where(Product.where(client_id: Client.arel_table[:id]).exists)
票数 7
EN

Stack Overflow用户

发布于 2015-08-31 02:53:59

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

代码语言:javascript
运行
复制
Client.where_exists(:products)
票数 6
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/14188872

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档