I have a table created in Materialized view from 10 different tables.
Part of it looks like this
group_name | value1 | value2 |
---|---|---|
group1 | 100 | 20 |
group2 | 200 | 40 |
unknown | 300 | 60 |
TOTAL | 600 | 120 |
I have to rearrange all values from rows with value group_name = 'unknown' to other rows. The final table should look like this
group_name | value1 | value2 |
---|---|---|
group1 | 200 | 40 |
group2 | 400 | 80 |
TOTAL | 600 | 120 |
So formula for 'group1' would be:
unknown x group1 x (TOTAL-unknown) + group1
The table is created with massive code and please note - I didn't write it, it was given to me and I have to work with it. I don't like how it looks, so please spare your anger. Anyway, the query looks like this:
TABLESPACE pg_default
AS
WITH table_value1 AS (
SELECT
table1.group_name,
table1.value1,
FROM table1
), table_value2 AS (
SELECT
table2.group_name,
table2.value2,
FROM table2
), TOTAL_groups AS (
SELECT
'value1'::text AS group_name,
sum(xy_table."value1")::numeric as results
FROM xy_table
UNION ALL
SELECT
'value2'::text AS group_name,
sum(xy_table."value2")::numeric as results
FROM xy_table
UNION ALL
SELECT
'unknown'::text AS group_name,
sum(xy_table."unknown")::numeric as results
FROM xy_table
), TOTAL AS (
SELECT
TOTAL_groups.group_name,
TOTAL_groups.results
FROM TOTAL_groups
UNION ALL
'TOTAL'::text AS group_name,
round(sum(TOTAL_groups.raba), 1) as results
FROM skupaj_energenti
)
SELECT
a.group_name,
COALESCE(a.results, 0::numeric) AS value1,
COALESCE(a.results, 0::numeric) AS value2
FROM table_value1 a
LEFT JOIN table_value2 b ON b.group_name = a.group_name
LEFT JOIN TOTAL c ON f.group_name = a.group_name
WITH DATA;
I have no idea how should I write such conditions in SQL. Please help.
Distribute 'unknown' row to other rows. Assuming value1, value2 are DECIMAL
select group_name, value1 * (1 + k1) value1, value2 * (1 + k2) value2
from tbl
cross join (
select sum(case group_name when 'unknown' then value1 end) / sum(case group_name when 'TOTAL' then value1 else -value1 end) k1,
sum(case group_name when 'unknown' then value2 end) / sum(case group_name when 'TOTAL' then value2 else -value2 end) k2
from tbl
where group_name in ('TOTAL', 'unknown')
) t
where tbl.group_name not in ('TOTAL', 'unknown')