6

所以我知道这是如何工作的

ActiveRecord::Base.connection_pool.with_connection do |conn|
   conn.execute(sql)
end

但我正在尝试使用与实际 Activerecord 模型的连接,所以类似于

conn.Url.first

有没有办法做这样的事情?

4

1 回答 1

12

发现这是不可能的,但是在 with_connection 块中,任何 ActiveRecord 调用都应该使用从 Rails 连接池中签出的连接

所以在这个例子中

ActiveRecord::Base.connection_pool.with_connection do |conn|
    Url.first
end

它应该从您的 database.yml :pool 设置中为 Rails 预留的池中检查一个连接,让您的活动记录调用使用它,然后将其重新检入

但是,这仅适用于 rails 3+ ...您可以在此处看到使这成为可能的代码更改

Rails 2.3(旧方式)http://apidock.com/rails/v2.3.8/ActiveRecord/ConnectionAdapters/ConnectionPool/with_connection

Rails 3 http://apidock.com/rails/v3.0.0/ActiveRecord/ConnectionAdapters/ConnectionPool/with_connection

这家伙在这篇博文中解释了补丁 http://coderrr.wordpress.com/2009/05/05/activerecords-with_connection-is-now-useful/

于 2012-05-13T01:54:06.303 回答