Альтернатива для наружного применения

Это мои столы

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 ;
Другие вопросы по тегам