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

Ruby on Rails中,您可以使用以下语法从数据库中找到记录:
<model_name>.find_by_<field_name>()

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

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

有人可以帮我记住吗?

解决方法

您可以使用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

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

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

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

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

相关文章

validates:conclusion,:presence=>true,:inclusion=>{...
一、redis集群搭建redis3.0以前,提供了Sentinel工具来监控各...
分享一下我老师大神的人工智能教程。零基础!通俗易懂!风趣...
上一篇博文 ruby传参之引用类型 里边定义了一个方法名 mo...
一编程与编程语言 什么是编程语言? 能够被计算机所识别的表...
Ruby类和对象Ruby是一种完美的面向对象编程语言。面向对象编...