【发布时间】:2018-03-27 09:07:48
【问题描述】:
我正在尝试在 postgresql 数据库上使用 full outer join 来获取具有缺失行的空值的表的联合。但是,它对我不起作用。
示例如下:
create temp table nutrient_names (
name text
);
insert into nutrient_names values
('fat'),
('sugar'),
('sodium'),
('total fat');
create temp table nutrients (
food_id int,
name text,
quantity float8
);
insert into nutrients values
(1, 'fat', 0.3),
(1, 'sugar', 15),
(1, 'sodium', 10),
(1, 'total fat', 25),
(2, 'sugar', 10),
(2, 'sodium', 4);
这是输出:
select n.name, n.food_id, n.quantity from nutrient_names nn
full outer join nutrients n
on nn.name = n.name
order by n.food_id, n.name;
+---------------------------------+
|name |food_id |quantity|
+---------------------------------+
| 'fat' |1 |'0.3' |
| 'sodium' |1 |'10' |
| 'sugar' |1 |'15' |
| 'total fat'|1 |'25' |
| 'sodium' |2 |'4' |
| 'sugar' |2 |'10' |
+---------------------------------+
我想要什么:
+---------------------------------+
|name |food_id |quantity|
+---------------------------------+
| 'fat' |1 |'0.3' |
| 'sodium' |1 |'10' |
| 'sugar' |1 |'15' |
| 'total fat'|1 |'25' |
| 'fat' |2 |null | <----
| 'sodium' |2 |'4' |
| 'sugar' |2 |'10' |
| 'total fat'|2 |null | <----
+---------------------------------+
【问题讨论】:
标签: sql postgresql outer-join