Rails 3 ActiveRecord方法链接,引擎盖下

假设您构建了一个涉及多个方法链接的查询,例如

Post.where('id > 10').limit(20).order('id asc').except(:order) 

我想知道幕后发生了什么? 据推测,链的每个部分都有助于构建一个SQL SELECT,一旦链完成,就会执行语句,创建模型等。它如何“知道”链的末端在哪里? 每个方法都返回一个创建SQL片段的ActiveRecord :: Relation吗?

你是对的,每个都返回一个ActiveRecord::Relation 。 每个方法调用都建立在它被调用的关系之上(除了第一个,它显然没有任何东西需要构建,因为它没有在关系上调用),并返回它。

它“知道”链的末尾是什么,因为在您尝试操作/访问数据之前,查询实际上并未执行,并且这样做(通常是隐式地)调用to_a运行exec_queries