ruby-on-rails – Ruby on Rails:如何设置“查找”选项以便不使用缓存

前端之家收集整理的这篇文章主要介绍了ruby-on-rails – Ruby on Rails:如何设置“查找”选项以便不使用缓存前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
Ruby on Rails中,您可以使用以下语法从数据库中找到记录: @H_404_2@<model_name>.find_by_<field_name>()

示例:User.find_by_email(‘test@test.test’),User.find_by_id(1),…

以前,如果我没有错,我会读到某个地方可以明确禁用“查找”操作的缓存,但我不记得如何.

有人可以帮我记住吗?

解决方法

您可以使用ActiveRecord :: QueryCache.uncached,如下所示: @H_404_2@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

在控制器中,它看起来像这样:

@H_404_2@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

显然,在一个模型中,你只需要做:

@H_404_2@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
原文链接:/ruby/266508.html

猜你在找的Ruby相关文章