Список пожеланий: SQL для стандартных отчетов

Я периодически сталкиваюсь с желанием взять один из стандартных отчётов (сегодня это «Объединённые просмотры страниц») и немного углубиться в него.

Вместо того чтобы начинать с нуля, было бы просто чудесно :christmas_tree: :gift: иметь возможность перейти от отчёта к его SQL-запросу для доработки.

Это не построено на SQL, но это не проблема, мы можем вывести это…

Вот общее руководство на Meta:

А именно: discourse/app/models/concerns/reports/consolidated_page_views.rb at main · discourse/discourse · GitHub

Оно построено с использованием модели Rails, ApplicationRequest, например:

[3] pry(main)> ApplicationRequest.last(10)
=> [#<ApplicationRequest:0x000055c8edcf99f8 id: 4798, date: Thu, 17 Nov 2022, req_type: "http_total", count: 3080>,
 #<ApplicationRequest:0x000055c8edcf9ac0 id: 4799, date: Thu, 17 Nov 2022, req_type: "http_background", count: 1014>,
 #<ApplicationRequest:0x000055c8edcf9bb0 id: 4800, date: Thu, 17 Nov 2022, req_type: "page_view_crawler", count: 539>,
 #<ApplicationRequest:0x000055c8edcf9c78 id: 4801, date: Thu, 17 Nov 2022, req_type: "http_2xx", count: 1929>,
 #<ApplicationRequest:0x000055c8edcf9d68 id: 4802, date: Thu, 17 Nov 2022, req_type: "http_4xx", count: 52>,
 #<ApplicationRequest:0x000055c8edcf9e30 id: 4803, date: Thu, 17 Nov 2022, req_type: "http_3xx", count: 85>,
 #<ApplicationRequest:0x000055c8edcf9f20 id: 4804, date: Thu, 17 Nov 2022, req_type: "page_view_anon", count: 40>,
 #<ApplicationRequest:0x000055c8edcf9fe8 id: 4805, date: Thu, 17 Nov 2022, req_type: "page_view_logged_in", count: 148>,
 #<ApplicationRequest:0x000055c8edcfa0d8 id: 4806, date: Thu, 17 Nov 2022, req_type: "page_view_logged_in_mobile", count: 134>,
 #<ApplicationRequest:0x000055c8edd00a00 id: 4807, date: Thu, 17 Nov 2022, req_type: "page_view_anon_mobile", count: 2>]

Соответствующая таблица, которая вам нужна, — application_requests (но я не вижу, чтобы она была доступна в Data Explorer, возможно, я что-то упустил?)

Типы запросов (req_type) в этом отчёте следующие:

  page_view_logged_in
  page_view_anon
  page_view_crawler

Это обычная операция суммирования и группировки, поэтому, вероятно, вы можете начать с консоли Rails:

ApplicationRequest.where(req_type:["page_view_logged_in", "page_view_anon", "page_view_crawler"]).where('date BETWEEN ? AND ?', '11/14/2022', '11/17/2022')

например

или эквивалент на SQL:

SELECT * FROM application_requests WHERE req_type IN (7, 8, 6) AND (date BETWEEN '11/14/2022' AND '11/17/2022')

Часть агрегации уже выполнена за вас, так как данные находятся в столбце count.