ruby-on-rails – Ruby on Rails:如何设置“查找”选项以便不使
发布时间:2020-12-16 22:01:55 所属栏目:百科 来源:网络整理
导读:在 Ruby on Rails中,您可以使用以下语法从数据库中找到记录: model_name.find_by_field_name() 示例:User.find_by_email(‘test@test.test’),User.find_by_id(1),… 以前,如果我没有错,我会读到某个地方可以明确禁用“查找”操作的缓存,但我不记得如何.
在
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 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |