con*_*t47 4 activerecord ruby-on-rails
所以我知道这是如何工作的
ActiveRecord::Base.connection_pool.with_connection do |conn|
conn.execute(sql)
end
Run Code Online (Sandbox Code Playgroud)
但我正在尝试使用与实际Activerecord模型的连接,所以类似于
conn.Url.first
Run Code Online (Sandbox Code Playgroud)
有没有办法做那样的事情?
con*_*t47 10
发现这是不可能的,但在with_connection块中,任何ActiveRecord调用都应该使用从Rails连接池中检出的连接
所以在这个例子中
ActiveRecord::Base.connection_pool.with_connection do |conn|
Url.first
end
Run Code Online (Sandbox Code Playgroud)
它应该在你的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/
| 归档时间: |
|
| 查看次数: |
4039 次 |
| 最近记录: |