File: complex_gitlab.sql

package info (click to toggle)
libpg-query 17-6.2.0-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 33,416 kB
  • sloc: ansic: 175,684; sql: 79,564; ruby: 1,605; makefile: 276; cpp: 221
file content (56 lines) | stat: -rw-r--r-- 2,128 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
-- From https://handbook.gitlab.com/handbook/enterprise-data/platform/sql-style-guide/
WITH my_data AS (
    SELECT my_data.*
    FROM
        prod.my_data_with_a_long_table_name my_data
        JOIN prod.other_thing ON true
    WHERE my_data.filter = 'my_filter'
), some_cte AS (
    SELECT
        DISTINCT
        id AS other_id, other_field_1, other_field_2, date_field_at,
        data_by_row, field_4, field_5,
        lag(other_field_2) OVER (
            PARTITION BY other_id, other_field_1
            ORDER BY 5
        ) AS previous_other_field_2
    FROM prod.my_other_data
),

/*
This is a very long comment: It is good practice to leave comments in code to
explain complex logic in CTEs or business logic which may not be intuitive to
someone who does not have intimate knowledge of the data source. This can help
new users familiarize themselves with the code quickly.
*/
final AS (
    SELECT
        -- This is a singel line comment
        my_data.field_1 AS detailed_field_1,
        my_data.field_2 AS detailed_field_2, my_data.detailed_field_3,
        date_trunc('month', some_cte.date_field_at) AS date_field_month,
        some_cte.data_by_row['id']::number AS id_field,
        iff(my_data.detailed_field_3 > my_data.field_2, true, false) AS is_boolean,
        CASE
            WHEN
                my_data.cancellation_date IS NULL
                AND my_data.expiration_date IS NOT NULL THEN my_data.expiration_date
            WHEN my_data.cancellation_date IS NULL THEN my_data.start_date + 7
            ELSE
                -- There is a reason for this number (BUG: this is supposed to be after the "7")
                my_data.cancellation_date
        END AS adjusted_cancellation_date,
        count(*) AS number_of_records, sum(some_cte.field_4) AS field_4_sum,
        max(some_cte.field_5) AS field_5_max
    FROM
        my_data
        LEFT JOIN some_cte ON my_data.id = some_cte.id
    WHERE
        my_data.field_1 = 'abc'
        AND (my_data.field_2 = 'def' OR my_data.field_2 = 'ghi')
    GROUP BY 1, 2, 3, 4, 5, 6
    HAVING count(*) > 1
    ORDER BY 8 DESC
)
SELECT *
FROM final