Active Record查询计算具有HABTM关联记录的视图的缓存键?

时间:2017-01-14 17:13:09

标签: ruby-on-rails caching activerecord fragment-caching

学生和家长有has_and_belongs_to_many的关系,都属于学校。

此查询返回最新的时间戳:

School.first.students.includes(:parents).maximum("parents.updated_at")

为什么不这样:

School.first.students.left_outer_joins(:parents).select("MAX(parents.updated_at)")

控制台日志意味着两者都执行相同的SQL:

SELECT MAX(parents.updated_at) FROM "students" LEFT OUTER JOIN "parents_students" ON "parents_students"."student_id" = "students"."id" LEFT OUTER JOIN "parents" ON "parents"."id" = "parents_students"."parent_id" WHERE "students"."school_id" = $1  [["school_id", 1]]

但第一个是唯一一个返回时间戳值的人。

我想使用第二种形式的原因是我希望能够做到这样的事情:

School.first.students.left_outer_joins(:parents).select('COUNT(students.*) AS student_count, COUNT(parents.*) AS parent_count, MAX(students.updated_at) AS student_latest_update, MAX(parents.updated_at) AS parent_latest_update')`<br>

为具有关联的视图计算缓存键。我目前正在使用执行冗余查询的低效数组密钥:

<% cache [batch_of_students, batch_of_students.includes(:parents).maximum("parents.updated_at")] do %>

1 个答案:

答案 0 :(得分:1)

你可以用拔毛来做。

School.first.students.left_outer_joins(:parents).pluck("MAX(parents.updated_at)")

然后,您可以使用

创建cache_key
cache_key = School.first.students.left_outer_joins(:parents)
  .pluck(%(
    COUNT(students.*),
    COUNT(parents.*), 
    MAX(students.updated_at), 
    MAX(parents.updated_at)))

返回一个包含这4个值的数组,这些值可以作为缓存键。

# [100, 100, 2015-08-24 02:14:07 UTC, 2015-08-24 02:14:07 UTC]