1

我有以下课程,其中有几个针对同一关联的counter_culture计数器:

class Book < ::ActiveRecord::Base
  belongs_to :user

  counter_culture :user
  counter_culture :user, column_name: Proc.new { |b| b.comedy? ? 'comedy_books_count' : nil }
  counter_culture :user, column_name: Proc.new { |b| b.hard_cover? ? 'hard_cover_books_count' : nil }
end

我遇到的问题是它使用几个查询执行更新:

UPDATE "users" SET "books_count" = COALESCE("books_count", 0) + 1 WHERE "users"."id" = $1  [["id", 1616]]
UPDATE "users" SET "comedy_books_count" = COALESCE("comedy_books_count", 0) + 1 WHERE "users"."id" = $1  [["id", 1616]]
UPDATE "users" SET "hard_cover_books_count" = COALESCE("hard_cover_books_count", 0) + 1 WHERE "users"."id" = $1  [["id", 1616]]

有没有办法通过在单个查询中执行更新来更有效地使用counter_culture ?

4

1 回答 1

0

每一行都被检测为一种特殊情况,他们很难知道哪一条可以优化,哪一条不能优化。所以我猜没有。

于 2021-03-16T09:05:47.483 回答