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

sea*_*and 7 activerecord ruby-on-rails

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

Post.where('id > 10').limit(20).order('id asc').except(:order)
Run Code Online (Sandbox Code Playgroud)

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

And*_*all 13

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

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