Add indexes to help IncomingLinksReport, but not much. Refactor to limit result set size, but it doesn't help perf much either. SELECT COUNT(DISTINCT ...) is still slow.

This commit is contained in:
Neil Lalonde 2013-07-31 14:57:31 -04:00
parent 2a388e14e3
commit 27498a912b
2 changed files with 18 additions and 10 deletions

View File

@ -62,8 +62,8 @@ class IncomingLinksReport
report.y_titles[:num_users] = I18n.t("reports.#{report.type}.num_users") report.y_titles[:num_users] = I18n.t("reports.#{report.type}.num_users")
num_clicks = link_count_per_domain num_clicks = link_count_per_domain
num_topics = topic_count_per_domain num_topics = topic_count_per_domain(num_clicks.keys)
num_users = user_count_per_domain num_users = user_count_per_domain(num_clicks.keys)
report.data = [] report.data = []
num_clicks.keys.each do |domain| num_clicks.keys.each do |domain|
report.data << {domain: domain, num_clicks: num_clicks[domain], num_topics: num_topics[domain], num_users: num_users[domain]} report.data << {domain: domain, num_clicks: num_clicks[domain], num_topics: num_topics[domain], num_users: num_users[domain]}
@ -71,20 +71,22 @@ class IncomingLinksReport
report.data = report.data.sort_by {|x| x[:num_clicks]}.reverse[0,10] report.data = report.data.sort_by {|x| x[:num_clicks]}.reverse[0,10]
end end
def self.per_domain def self.link_count_per_domain(limit=10)
@per_domain_query ||= IncomingLink.where('created_at > ? AND domain IS NOT NULL', 30.days.ago).group('domain') IncomingLink.where('created_at > ? AND domain IS NOT NULL', 30.days.ago).group('domain').order('count_all DESC').limit(limit).count
end end
def self.link_count_per_domain def self.per_domain(domains)
per_domain.count IncomingLink.where('created_at > ? AND domain IN (?)', 30.days.ago, domains).group('domain')
end end
def self.topic_count_per_domain def self.topic_count_per_domain(domains)
per_domain.count('topic_id', distinct: true) # COUNT(DISTINCT) is slow
per_domain(domains).count('topic_id', distinct: true)
end end
def self.user_count_per_domain def self.user_count_per_domain(domains)
per_domain.count('user_id', distinct: true) # COUNT(DISTINCT) is slow
per_domain(domains).count('user_id', distinct: true)
end end

View File

@ -0,0 +1,6 @@
class AddReportIndexToIncomingLinks < ActiveRecord::Migration
def change
add_index :incoming_links, [:created_at, :user_id]
add_index :incoming_links, [:created_at, :domain]
end
end