-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathkyu6_present_JSON_data_the_SQL_way.sql
26 lines (25 loc) · 1.23 KB
/
kyu6_present_JSON_data_the_SQL_way.sql
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
-- Present JSON data the SQL way
--
-- https://www.codewars.com/kata/5daf515c3affec002b2fb921/train/sql
--
-- Given the database where users are stored in JSON format, fetch the records splitting the data into
-- separate columns
--
-- Notes
-- The private field determines whether the user's email address should be publicly visible
-- If the profile is private, email_address should equal "Hidden"
-- The users may have multiple email addresses
-- If no email addresses are provided, email_address should equal "None"
-- If there're multiple email addresses, the first one should be shown
-- The date_of_birth is in the yyyy-mm-dd format
-- The age fields represents the user's age in years
-- Order the result by the first_name, and last_name columns
SELECT data->> 'first_name' AS first_name, data->> 'last_name' AS last_name,
EXTRACT(YEAR FROM AGE(now(), (data->> 'date_of_birth')::date))::integer AS age,
CASE
WHEN data->> 'private'='true' THEN 'Hidden'
WHEN data->> 'private' = 'false' AND data#>> '{email_addresses, 0}' ISNULL THEN 'None'
ELSE data#>> '{email_addresses, 0}'
END AS email_address
FROM users
ORDER BY first_name, last_name;