Rails,为什么连接返回具有非唯一值的数组?

2024-04-25

我使用 Rails 3 为例,但我相信 Rails 2.3 也是如此。

假设,我有一个有很多位置的模型城市。我尝试寻找有地点的城市。

我使用以下代码:

City.joins(:locations)

但输出数组是:

=> [#<City id: 5, name: "moscow", created_at: "2010-07-02 15:09:16", updated_at: "2010-07-02 15:09:16">, #<City id: 5, name: "moscow", created_at: "2010-07-02 15:09:16", updated_at: "2010-07-02 15:09:16">, #<City id: 5, name: "moscow", created_at: "2010-07-02 15:09:16", updated_at: "2010-07-02 15:09:16">, #<City id: 5, name: "moscow", created_at: "2010-07-02 15:09:16", updated_at: "2010-07-02 15:09:16">]

数组长度为 4(莫斯科的位置数)。

在什么情况下它可以有用?输出数组中一个对象的 4 个副本的目的是什么?

我可以使用 City.joins(:locations).uniq,但我失去了 arel 的敏捷性。

我有两个问题:

  1. 为什么 join 返回非唯一数组?
  2. 为此目的,首选使用什么来代替连接?

Join 本质上是说合并两个表并将其视为一张表,发送回找到的任何内容。这意味着它会找到您的城市和位置的每种组合(Rails 会根据模型中的belongs_to/has_many 关系进行匹配来帮助您)。

Doing City.joins(:locations)将用于查找城市中的所有位置。以另一种方式做(Location.joins(:city))将用于查找某个位置所在的城市。

现在,要查找具有某些位置的城市列表,您可以尝试City.select(:city).joins(:locations).group('cities.id') The select()子句告诉它只带回 City,而 group() 子句告诉它不要带回重复的副本。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Rails,为什么连接返回具有非唯一值的数组? 的相关文章

随机推荐

  • 分别处理spark中的多个目录

    我在 HDFS 中有一个目录列表 每个目录包含多个文件 我的目标是将一个目录中的所有文件合并为一个文件 但每个目录分别合并 在 Spark 中执行此操作最快的方法是什么 顺序迭代所有目录太慢 所以我想并行进行 一种解决方案可能是使用线程池
  • Java 8 流过滤:IN 子句

    List
  • 自动滚动图库小部件

    我需要实现一个画廊 它一次滚动一个项目 并且可以执行 自动滚动 即每隔几秒钟 它会自动滚动到下一个项目 根据这个线程 Android 以编程方式在图库小部件中的图像之间设置动画 https stackoverflow com questio
  • Zend Framework 路由:.html 扩展名

    我知道我以前见过这样做 但我在任何地方都找不到信息 我需要能够在 Zend Framework 中使用 html 扩展名进行路由 IE controller action html 应路由到适当的控制器 操作 我们有一个想法 用 htacc
  • 形成两个列表并集的最简单方法

    将两个列表 例如 A 和 B 的元素相互比较 并且仅当 A 中不存在时才将 B 中存在的元素添加到 A 中 最简单的方法是什么 为了显示 取列表 A 1 2 3 列表 B 3 4 5 所以在 AUB 手术之后我想要 列表 A 1 2 3 4
  • 使用装箱值类型作为锁定语句的锁是否安全?

    的文档lock https learn microsoft com en us dotnet csharp language reference keywords lock statement声明非常简单 lock x Your code
  • Spring集成MQTT发布订阅多个主题

    我正在尝试构建一个订阅多个 mqtt 主题的应用程序 获取信息 处理它并形成 xml 并在处理时触发一个事件 以便这些可以发送到某个云服务器 并将成功的响应从那里发送回MQTT 通道
  • Safari 中的 CSS 动画延迟错误

    我最近在 Safari 中遇到了一些与 CSS 动画有关的奇怪行为 并且在操作 DOM 时无法更新元素位置 我拍了一些 GIF 来说明这一点 在 Chrome 中 http recordit co cCim1IwyMc http recor
  • 折叠时,条子标题从中心向左颤动

    我的目标是遵循我的设计 受到三星天气的启发 但是当您刚开始学习时 实现代码很困难 展开时标题应居中 折叠时标题应保留在左上角 到目前为止 这是我的代码和我当前的进度 棘手的部分是将标题移到中心 Scaffold backgroundColo
  • 如何为角度 2/4 中的动画状态指定类名称?

    我正在使用 4 1 3 版本的角度动画 下面是代码 Component selector my fader animations trigger visibilityChanged state true style opacity 1 tr
  • :expire_after 时间结束后,Rails 会话会发生什么?

    会话会变为零吗 更改仅在下一次请求时生效吗 我想我现在只问了三个问题 您可以尝试使用类似的设置进行探索 AppName Application config session store cookie store key session ke
  • register_shutdown_function() 仍然输出原始错误消息

    我正在尝试用自定义函数替换内置的 php shutdown function 它工作得很好 但是 它仍然在我的新错误消息上方输出原始错误 内置错误
  • ASP.NET 中的基本页面

    您是否建议在 Visual Studio 中创建的每个网站中创建一个基本页面作为父类 确切的优点 缺点是什么 如果您想重写 ASP NET 中某些内容的工作方式 将其构建到基类中比在每个页面中包含代码会更有效 我这样做的两个具体实例是 是否
  • Azure Functions 数据库连接字符串

    如何添加或访问app configAzure 函数中的文件添加数据库连接字符串 如果你不应该添加app config并且有更好的方法来访问外部数据库来执行该功能 请让我知道最佳实践 谢谢 Jan V almost钉住了它 这促使我在loca
  • Retrofit 是否在主线程上进行网络调用?

    我正在尝试在 Android 上探索 Retrofit OkHttp 这是我在网上找到的一些代码 RestAdapter restAdapter new RestAdapter Builder setExecutors executor e
  • 通过列名动态访问游标

    我可以动态访问游标的列吗 我的意思是名字 像这样的东西 declare v cursor select from emp begin FOR reg IN v cursor LOOP dbms output put line reg col
  • 如何知道 ASP.net 是哪个版本?

    通过查看ASP NET项目 我们如何知道它内置的是哪个版本的ASP NET 有人可以列出识别版本的不同方法吗 谢谢 您需要小心此处使用的方法 因为 ASP NET 下的 NET 框架的某些更新似乎会在以前的版本号下运行 例如 ASP NET
  • 重写后.htaccess图像不显示

    我有一个问题 URL 已被这样重写 RewriteEngine on RewriteCond REQUEST URI index php RewriteRule index php test 1 NC L 我的图像和 CSS 样式都没有被应
  • VB.NET Custom Control(自定义绘图)刷新问题

    我用两个项目创建了一个简单的解决方案 第一个项目 类库 包含一个名为 Container 的自定义控件 它用圆角绘制自身 第二个项目 Windows 窗体 是一个测试应用程序 如果我在第二个项目的主窗体中添加一个容器实例 它会很好地显示圆角
  • Rails,为什么连接返回具有非唯一值的数组?

    我使用 Rails 3 为例 但我相信 Rails 2 3 也是如此 假设 我有一个有很多位置的模型城市 我尝试寻找有地点的城市 我使用以下代码 City joins locations 但输出数组是 gt