[Rails] preload vs includes

栏目: Ruby · 发布时间: 6年前

内容简介:写了这么长时间的会生成分开的两条查询, 类似:也因为是分开的两个查询, 所以, 不能在

写了这么长时间的 Rails , 大部分时候都是用 includes , 鲜少使用到 preload . 所以, 没太在意这俩的区别. 最近写一个比较复杂的报表 SQL 时候总算踩到坑了.

preload

会生成分开的两条查询, 类似:

Product.preload(:taxon).load
# Product Load (33.9ms)  SELECT "products".* FROM "products"
# Taxon Load (1.7ms)  SELECT "taxons".* FROM "taxons" WHERE "taxons"."id" IN (9, 12, 60, 61, 20, 18, 46, 47, 15, 78, 8, 19, 14)

也因为是分开的两个查询, 所以, 不能在 WHEREORDER BY 的分句中使用关联表. 比如:

[2] pry(main)> Product.preload(:taxon).where(taxons: {id: 9}).load
# ActiveRecord::StatementInvalid: PG::UndefinedTable: ERROR:  missing FROM-clause entry for table "taxons"

includes

之所以大部分时候用 includes 就可以了, 是因为 includes 也能跟 preload 生成同样的查询语句.

Product.includes(:taxon).load
# Product Load (33.9ms)  SELECT "products".* FROM "products"
# Taxon Load (1.7ms)  SELECT "taxons".* FROM "taxons" WHERE "taxons"."id" IN (9, 12, 60, 61, 20, 18, 46, 47, 15, 78, 8, 19, 14)

其实是一样的. 但除此之外, 如果有基于关联表的 WHERE 或者 ORDER BY 分句的话, 此时生成的语句不再是两条, Rails 会自动变为使用 LEFT OUTER JOIN 单条完成. 比如:

Product.includes(:taxon).order("taxons.id").load
# SQL (109.8ms)  SELECT "products"."id" AS t0_r0, "products"."name" AS t0_r1, "products"."sku" AS t0_r2, "products"."taxon_id" AS t0_r3, "taxons"."id" AS t1_r0, "taxons"."name" AS t1_r1 FROM "products" LEFT OUTER JOIN "taxons" ON "taxons"."id" = "products"."taxon_id" ORDER BY taxons.id

除了 LEFT JOIN 以外, 还可以看到 SELECT 了两个表的所有字段. 这也造就了写报表 SQL 踩坑的点了.

因为用到了 GROUP BY 语句, 但其实又不需要 includes 自动给的额外 SELECT 的字段, 于是…

ActiveRecord::StatementInvalid: PG::GroupingError: ERROR:  column "snapshots.id" must appear in the GROUP BY clause or be used in an aggregate function

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

顾客要买什么

顾客要买什么

[美]迈克尔·西尔 / 方海萍 / 中国人民大学出版社 / 2006-10 / 38.00元

《顾客要买什么》告诉我们全球的中产阶级如何正在改造着消费品市场:对低价的产品和服务进行趋低消费,对于高端的产品和服务要趋优消费,而对于日趋乏味、价值降低的中档商品则避而远之。这些消费者大多是女性,教育程度高,可支配收入多,买东西的时候也更会精打细算。她们选购、使用商品和服务的时候都是有目的的,有一种大权在握的感觉。消费对她们来说并不是非做不可的麻烦事,也不是什么无法避免的琐事,而是如何明智地花钱的......一起来看看 《顾客要买什么》 这本书的介绍吧!

RGB转16进制工具
RGB转16进制工具

RGB HEX 互转工具

HSV CMYK 转换工具
HSV CMYK 转换工具

HSV CMYK互换工具