6

我知道在 rails 2.3.2 ActiveRecord 查询被缓存,即您可能会在开发/生产日志中看到一些内容:

CACHE (0.0ms)   SELECT * FROM `users` WHERE `users`.`id` = 1

我想知道相同的原则是否适用于 rake 任务。

我有一个 rake 任务,它将查询很多不同的模型,我想知道我是否应该实现自己的缓存,或者默认情况下是否包含此行为。

另外,有没有办法查看 rake 任务期间执行的 sql 查询?类似于开发/生产日志

4

3 回答 3

3

默认情况下,不会为 rake 任务启用 SQL 缓存。您可以将代码包装在缓存块中,如下所示:

task :foobar => :environment do
  ActiveRecord::Base.connection.cache do
    User.find 1 # Will hit the db
    User.find 1 # Will hit the cache
  end
end

这本质上是 Rails 对控制器操作所做的。请注意,缓存使用内存,而 rake 任务倾向于处理大量数据,这可能会给您带来问题。您可以选择性地选择退出部分代码的缓存,使用uncached

于 2014-12-16T14:46:55.077 回答
2

您正在谈论 ActiveRecord 查询缓存。这也应该在 Rake-Tasks 中工作,前提是您在启用缓存的环境中运行它们,例如production. 有关示例,请参阅Rails 缓存指南。

对于您的情况,它可能是也可能不是正确的缓存类型:

u1=User.find 1  # loads user1 first time from DB
u2=User.find 2  # loads user2 first time from DB
u1again = User.find 1 # loads user1 from cache
all = User.all # loads user1 and user2 from DB again
于 2009-07-09T12:11:56.903 回答
1

rake 任务将在您指定的环境中运行,在这种情况下,它将采用该环境的规则。

您可以从命令行设置 rails env:

RAILS_ENV=test

日志记录可以设置为 rake 的一部分,您应该在正常的 Rails 日志中看到这一点。

于 2009-05-19T00:50:39.287 回答