sql >> Databáze >  >> RDS >> PostgreSQL

Jak mohu sloučit sloupce ze dvou tabulek do jednoho výstupu?

Určení sloupců v dotazu by mělo stačit:

select a.col1, b.col2, a.col3, b.col4, a.category_id 
from items_a a, items_b b 
where a.category_id = b.category_id

měli byste udělat trik s ohledem na výběr sloupců, které chcete.

Chcete-li obejít skutečnost, že některá data jsou pouze v položkách_a a některá data pouze v položkách_b, můžete provést:

select 
  coalesce(a.col1, b.col1) as col1, 
  coalesce(a.col2, b.col2) as col2,
  coalesce(a.col3, b.col3) as col3,
  a.category_id
from items_a a, items_b b
where a.category_id = b.category_id

Funkce koalesce vrátí první nenulovou hodnotu, takže pro každý řádek, pokud col1 není null, použije tuto hodnotu, jinak získá hodnotu z col2 atd.



  1. Použití PgBouncer Connection Pooler pro PostgreSQL s ClusterControl 1.8.2

  2. Agregace (x,y) souřadnicových mračen bodů v PostgreSQL

  3. Jak mohu použít operátory PostgreSQL JSON(B) obsahující otazník? přes JDBC

  4. jak předat název tabulky jako parametr do uložené procedury?