加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

ruby-on-rails – 为什么ActiveRecord:包含两个查询?

发布时间:2020-12-17 01:26:23 所属栏目:百科 来源:网络整理
导读:我只是学习ActiveRecord和SQL而且我的印象是:include做一个SQL查询.所以,如果我这样做: Show.first :include = :artist 它将执行一个查询,该查询将返回第一个节目和艺术家.但是看看生成的SQL,我看到两个查询: [2013-01-08T09:38:00.455705 #1179] DEBUG -
我只是学习ActiveRecord和SQL而且我的印象是:include做一个SQL查询.所以,如果我这样做:

Show.first :include => :artist

它将执行一个查询,该查询将返回第一个节目和艺术家.但是看看生成的SQL,我看到两个查询:

[2013-01-08T09:38:00.455705 #1179] DEBUG -- :   Show Load (0.5ms)  SELECT `shows`.* FROM `shows` LIMIT 1
[2013-01-08T09:38:00.467123 #1179] DEBUG -- :   Artist Load (0.5ms)  SELECT `artists`.* FROM `artists` WHERE `artists`.`id` IN (2)

我看到了作者之一的Railscast视频:include vs:join我在控制台上看到了输出SQL,这是一个很大的SQL查询,但它只是一个查询.我只是想知道这是不是应该是这样或者我错过了什么?

解决方法

使用:includes是一种提供急切加载的解决方案.它将在您的示例中加载最多两个查询.如果您要更改查询Show.all:include => :艺术家.这也只会调用两个查询.

更好的解释:Active Record Querying Eager Loading

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读