Tarihleri karşılaştırma

SQL ile Raporlama

Tyler Pernes

Learning & Development Consultant

Yanıtlanacak sorular

  1. Geçen ay vs önceki ay?
  2. Yuvarlanan 7 gün?
original_table
+------------+----------+
| date       | revenue  |
|------------+----------|
| 2018-01-01 | 400      |
| 2018-01-02 | 380      |
| 2018-01-03 | 625      |
+------------+----------+
SQL ile Raporlama

Aydan aya karşılaştırma

  • LAG(value, offset), geçerli satırdan önceki offset satırdaki value değerini döndürür.
  • LEAD(value, offset), geçerli satırdan sonraki offset satırdaki value değerini döndürür.

SQL ile Raporlama

Aydan aya karşılaştırma

Adım 1: geliri aya göre gösterin

SELECT
    DATE_PART('month',date) AS month,
    SUM(revenue) as current_rev
FROM original_table
GROUP BY month;

Adım 2: önceki ayın geliri

SELECT
    DATE_PART('month',date) AS month,
    SUM(revenue) as current_rev,
    LAG(SUM(revenue)) OVER (ORDER BY DATE_PART('month',date)) AS prev_rev
FROM original_table
GROUP BY month;
SQL ile Raporlama

Aydan aya karşılaştırma

Adım 3: yüzde değişim hesabı

SELECT
    DATE_PART('month',date) AS month,
    SUM(revenue) as current_rev,
    LAG(SUM(revenue)) OVER (ORDER BY DATE_PART('month',date)) AS prev_rev,
    SUM(revenue)
    /
    LAG(SUM(revenue)) OVER (ORDER BY DATE_PART('month',date))-1 AS perc_change
FROM original_table
GROUP BY month;
SQL ile Raporlama

Aydan aya karşılaştırma

Adım 3: yüzde değişim hesabı

+--------+--------------+-----------+--------------+
| month  | current_rev  | prev_rev  | perc_change  |
|--------+--------------+-----------+--------------|
| 01     | 15000        | null      | null         |
| 02     | 14000        | 15000     | -.06         |
| 03     | 21000        | 14000     | .50          |
+--------+--------------+-----------+--------------+
SQL ile Raporlama

Yuvarlanan hesaplamalar

  • Yalnızca 7 satırı dikkate alın

Yeni ifade: ROWS BETWEEN

SUM(value) OVER (ORDER BY value ROWS BETWEEN N PRECEDING AND CURRENT ROW)
SQL ile Raporlama

Yuvarlanan hesaplamalar

Yuvarlanan toplam sorgusu

SELECT 
    date,
    SUM(SUM(revenue)) OVER 
    (ORDER BY date ROWS BETWEEN 6 PRECEDING AND CURRENT ROW) AS weekly_revenue
FROM original_table
GROUP BY date;
SQL ile Raporlama

Yeni tablo: web_data

web_data
+------------+-------------+--------+
| date       | country_id  | view   |
|------------+-------------+--------|
| 2018-01-01 | 1           | 24313  |
| 2018-01-01 | 2           | 3768   |
| 2018-01-01 | 3           | 26817  |
+------------+-------------+--------+
SQL ile Raporlama

Hadi pratik yapalım!

SQL ile Raporlama

Preparing Video For Download...