我准备了一个 sqlFiddle,位于此处:http://sqlfiddle.com/#!2/951c1/2/1
我有 3 个表(汽车、颜色和 car_color_history)。在 colors
中有我感兴趣的带有某种元数据的颜色。在 cars
中,有一堆带有“wanted_color”键的汽车告诉汽车改变给定的颜色。在 car_color_history
中,有所有的条目,在什么特定时间汽车有什么颜色。
我现在想要的是查看/选择语句,以获取所有汽车的当前和想要颜色信息。
我的第一个想法是用左连接和某种 GROUP BY 魔术来做到这一点,但直到现在,我还无法让它工作
一个可行的解决方案是带有子选择的 fiddle 中的第二个选择。我是否正确认为这不是一个很好的解决方案,因为它很慢?另外,我必须为每个显示的列提供子选择:(
谁有解决办法?
最佳答案
select
ca.carkey,
description,
cow.other_info as wanted_color,
cco.other_info as current_color,
cch.datetime as current_color_datetime
from
cars ca
left join
colors cow on ca.wanted_color = cow.colorkey
left join (
select distinct on (carkey) *
from car_color_history
order by carkey, datetime desc
) cch using(carkey)
left join
colors cco on cch.colorkey = cco.colorkey
关于历史表中的 SQL LEFT JOIN,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25162419/