Альтернатива для наружного применения
Это мои столы
create table #vehicles (vehicle_id int, sVehicleName varchar(50))
create table #location_history ( vehicle_id int, location varchar(50), date datetime)
insert into #vehicles values
(1, 'MH 14 aa 1111'),
(2,'MH 12 bb 2222'),
(3,'MH 13 cc 3333'),
(4,'MH 42 dd 4444')
insert into #location_history values
( 1, 'aaa', getdate()),
( 1, 'bbb' , getdate()),
( 2, 'ccc', getdate()),
( 2, 'ddd', getdate()),
(3, 'eee', getdate()),
( 3, 'fff', getdate()),
( 4, 'ggg', getdate()),
( 4 ,'hhh', getdate())
Это запрос, который я выполняю на сервере SQL.
select v.sVehicleName as VehicleNo, ll.Location
from #vehicles v outer APPLY
(select top 1 Location from #location_history where vehicle_id = v.vehicle_id
) ll
Это вывод на SQL сервере.
VehicleNO|Location
MH14aa1111 | aaa
MH12bb2222 | ccc
MH13cc3333 | eee
MH42dd4444 |ggg
Я хочу выполнить это в MySQL. и я хочу такой же вывод, упомянутый выше.
1 ответ
Во-первых, запрос SQL Server на самом деле не имеет смысла, потому что вы используете top
без order by
,
Предположительно, вы намереваетесь что-то вроде этого:
select v.sVehicleName as VehicleNo, ll.Location
from #vehicles v outer APPLY
(select top 1 Location
from #location_history
where vehicle_id = v.vehicle_id
order by ?? -- something to indicate ordering
) ll;
Вам нужен метод, чтобы получить последнюю запись для каждого транспортного средства. Я думаю, что в нормальных условиях date
будет содержать эту информацию - однако, это не так в ваших данных образца.
При условии, что date
действительно содержит уникальные значения, тогда вы можете сделать:
select v.sVehicleName as VehicleNo, ll.Location
from vehicles v join
location_history lh
using (vehicle_id)
where lh.date = (select max(lh2.date)
from location_history lh2
where lh2.vehicle_id = lh.vehicle_id
);
В противном случае вы можете делать что хотите, используя коррелированный подзапрос. Тем не менее, это вернет произвольное значение соответствия на самую последнюю дату:
select v.sVehicleName as VehicleNo,
(select ll.Location
from location_history lh2
where lh2.vehicle_id = lh.vehicle_id
order by date desc
limit 1
) as location
from vehicles v ;