Full Join with partitions in PostgreSQL
data:image/s3,"s3://crabby-images/9b1a3/9b1a346233c8f6a4c188d38b66b60fb81a7e0a72" alt="Jeremy Greze"
postgresql, sql
We have two tables with a column that partitions the data, for example a date
column in the format YYYYY-MM-DD.
We want to join the two tables exhaustively (FULL OUTER JOIN
) but in a way that keeps our partitioning and with a condition (a id match for example).
select
COALESCE("input1"."date", "input2"."date") as "date",
-- ...
-- for example:
"input1"."my_id" IS NOT NULL AS "exist_in_input1",
"input2"."my_id" IS NOT NULL AS "exist_in_input2",
COALESCE("input1"."my_id", "input2"."my_id") AS "my_id",
from "input1"
full outer join "input2"
"input1"."my_id" = "input2"."my_id" -- just an example
and
"input1"."date" = "input2"."date"
where -- if you want to build only one partition
"input1"."date" = '2017-02-26' or "input2"."date" = '2017-02-26'
This is an example with PostgreSQL. But it does not work with MySQL.