use*_*052 13 search caching ruby-on-rails find ruby-on-rails-3
在Ruby on Rails中,您可以使用以下语法从数据库中查找记录:
<model_name>.find_by_<field_name>()
Run Code Online (Sandbox Code Playgroud)
例如:User.find_by_email('test@test.test'),User.find_by_id(1),...
前一段时间,如果我没有错,我会在某处读到你可以明确禁用"查找"操作的缓存,但我不记得是怎么回事.
有人可以帮我记住吗?
von*_*rad 22
你可以ActiveRecord::QueryCache.uncached像这样使用:
User.find_by_email('test@test.test')
User.find_by_email('test@test.test') # Will return cached result
User.uncached do
User.find_by_email('test@test.test')
User.find_by_email('test@test.test') # Will query the database again
end
Run Code Online (Sandbox Code Playgroud)
在控制器中,它看起来像这样:
def show # users#index action
User.uncached do
@user = User.find_by_email('test@test.test')
@another_user = User.find_by_email('test@test.test') # Will query database
end
User.find_by_email('test@test.test') # Will *not* query database, as we're outside of the Users.uncached block
end
Run Code Online (Sandbox Code Playgroud)
显然,在模型中,您只需要:
class User < ActiveRecord::Base
def self.do_something
uncached do
self.find_by_email('test@test.test')
self.find_by_email('test@test.test') # Will query database
end
end
end
User.do_something # Will run both queries
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
5306 次 |
| 最近记录: |