From 088b4ae1e2dbc44ef82f3b965b8f5b8ab2444e78 Mon Sep 17 00:00:00 2001 From: Tom Hughes Date: Thu, 30 Apr 2009 07:54:26 +0000 Subject: [PATCH] Do the statistics generation in a transaction. --- script/statistics | 132 +++++++++++++++++++++++----------------------- 1 file changed, 67 insertions(+), 65 deletions(-) diff --git a/script/statistics b/script/statistics index b076bef30..f04879359 100755 --- a/script/statistics +++ b/script/statistics @@ -15,84 +15,86 @@ puts "" puts "

OpenStreetMap stats report run at #{start_time.to_s}

" begin - user_count = User.count(:conditions => "active = 1") - tracepoint_count = Tracepoint.count() - node_count = Node.count(:conditions => "visible = true") - way_count = Way.count(:conditions => "visible = true") - relation_count = Relation.count(:conditions => "visible = true") - - puts "" - puts "" - puts "" - puts "" - puts "" - puts "" - puts "
Number of users#{user_count}
Number of uploaded GPS points#{tracepoint_count}
Number of nodes#{node_count}
Number of ways#{way_count}
Number of relations#{relation_count}
" - - puts "

Top 50 users for uploads of GPS data

" - puts "" - puts "" - - Trace.sum(:size, :group => :user_id, :order => "sum_size DESC", :limit => 50).each do |user, count| - display_name = User.find(user).display_name.gsub('@', ' at ').gsub('.', ' dot ') - puts "" - end - - puts "
UserNumber of Points
#{display_name}#{count}
" - - puts "

Number of users editing over the past...

" - puts "" - puts "" + ActiveRecord::Base.transaction do + user_count = User.count(:conditions => "active = 1") + tracepoint_count = Tracepoint.count() + node_count = Node.count(:conditions => "visible = true") + way_count = Way.count(:conditions => "visible = true") + relation_count = Relation.count(:conditions => "visible = true") + + puts "
Data TypeDayWeekMonth
" + puts "" + puts "" + puts "" + puts "" + puts "" + puts "
Number of users#{user_count}
Number of uploaded GPS points#{tracepoint_count}
Number of nodes#{node_count}
Number of ways#{way_count}
Number of relations#{relation_count}
" + + puts "

Top 50 users for uploads of GPS data

" + puts "" + puts "" + + Trace.sum(:size, :group => :user_id, :order => "sum_size DESC", :limit => 50).each do |user, count| + display_name = User.find(user).display_name.gsub('@', ' at ').gsub('.', ' dot ') + puts "" + end - day_count = Trace.count(:user_id, :distinct => true, - :conditions => "timestamp > NOW() - '1 DAY'::INTERVAL") - week_count = Trace.count(:user_id, :distinct => true, - :conditions => "timestamp > NOW() - '7 DAYS'::INTERVAL") - month_count = Trace.count(:user_id, :distinct => true, - :conditions => "timestamp > NOW() - '28 DAYS'::INTERVAL") + puts "
UserNumber of Points
#{display_name}#{count}
" - puts "GPX Files#{day_count}#{week_count}#{month_count}" + puts "

Number of users editing over the past...

" + puts "" + puts "" - day_count = OldNode.count(:user_id, :distinct => true, :joins => :changeset, + day_count = Trace.count(:user_id, :distinct => true, :conditions => "timestamp > NOW() - '1 DAY'::INTERVAL") - week_count = OldNode.count(:user_id, :distinct => true, :joins => :changeset, + week_count = Trace.count(:user_id, :distinct => true, :conditions => "timestamp > NOW() - '7 DAYS'::INTERVAL") - month_count = OldNode.count(:user_id, :distinct => true, :joins => :changeset, + month_count = Trace.count(:user_id, :distinct => true, :conditions => "timestamp > NOW() - '28 DAYS'::INTERVAL") - puts "" + puts "" + + day_count = OldNode.count(:user_id, :distinct => true, :joins => :changeset, + :conditions => "timestamp > NOW() - '1 DAY'::INTERVAL") + week_count = OldNode.count(:user_id, :distinct => true, :joins => :changeset, + :conditions => "timestamp > NOW() - '7 DAYS'::INTERVAL") + month_count = OldNode.count(:user_id, :distinct => true, :joins => :changeset, + :conditions => "timestamp > NOW() - '28 DAYS'::INTERVAL") - puts "
Data TypeDayWeekMonth
Nodes#{day_count}#{week_count}#{month_count}
GPX Files#{day_count}#{week_count}#{month_count}
" + puts "Nodes#{day_count}#{week_count}#{month_count}" + + puts "" - puts "

Top users editing over the past...

" - puts "" - puts "" - - day_users = OldNode.count(:conditions => "timestamp > NOW() - '1 DAY'::INTERVAL", - :joins => :changeset, :group => :user_id, - :order => "count_all DESC") - week_users = OldNode.count(:conditions => "timestamp > NOW() - '7 DAYS'::INTERVAL", - :joins => :changeset, :group => :user_id, - :order => "count_all DESC", :limit => 60) - month_users = OldNode.count(:conditions => "timestamp > NOW() - '28 DAYS'::INTERVAL", + puts "

Top users editing over the past...

" + puts "
DayWeekMonth
" + puts "" + + day_users = OldNode.count(:conditions => "timestamp > NOW() - '1 DAY'::INTERVAL", :joins => :changeset, :group => :user_id, - :order => "count_all DESC", :limit => 60) - - SyncEnumerator.new(day_users, week_users, month_users).each do |row| - puts "" - row.each do |column| - if column.nil? - puts "" - else - display_name = User.find(column[0]).display_name.gsub('@', ' at ').gsub('.', ' dot ') - count = column[1] - puts "" + :order => "count_all DESC") + week_users = OldNode.count(:conditions => "timestamp > NOW() - '7 DAYS'::INTERVAL", + :joins => :changeset, :group => :user_id, + :order => "count_all DESC", :limit => 60) + month_users = OldNode.count(:conditions => "timestamp > NOW() - '28 DAYS'::INTERVAL", + :joins => :changeset, :group => :user_id, + :order => "count_all DESC", :limit => 60) + + SyncEnumerator.new(day_users, week_users, month_users).each do |row| + puts "" + row.each do |column| + if column.nil? + puts "" + else + display_name = User.find(column[0]).display_name.gsub('@', ' at ').gsub('.', ' dot ') + count = column[1] + puts "" + end end + puts "" end - puts "" - end - puts "
DayWeekMonth
#{count} #{display_name}
#{count} #{display_name}
" + puts "" + end rescue Exception => e puts "

Exception: #{e.to_s}
#{e.backtrace.join('
')}

" end -- 2.43.2