尝试使用ActiveRecord :: Base.connection_pool.with_connection做一些事情

时间:2012-05-09 19:12:29

标签: ruby-on-rails activerecord

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

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

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

conn.Url.first

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

1 个答案:

答案 0 :(得分:10)

发现这是不可能的,在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/