Я использую MS ACCESS 2003
ИМЯ ТАБЛИЦЫ -> tmp_cardevent
PERSONID CARDEVENTDATE CARDEVENTTIME
5008 20090805 080000
5008 20090805 140000
5008 20090809 180000
5008 20090809 220000
3405 20090805 080000
3405 20090805 180000
3405 20090809 070000
3405 20090809 230000
3010 20080806 090000
3010 20080806 230000
3010 20080810 100000
3010 20080810 160000
Я хочу отобразить текущее и предыдущее время для идентификатора человека.
Предыдущий день означает не вчерашний день, а предыдущее время cardevent для конкретного человека.
Я делаю следующий запрос для получения значения предыдущей строки
select t1.Personid,
t1.cardeventdate,
t1.cardeventtime,
t2.Personid,
t2.cardeventdate,
t2.cardeventtime
from tmp_cardevent t1 inner join tmp_cardevent t2 on t1.cardno = t2.cardno
where t2.cardeventdate = (
select max(cardeventdate)
from tmp_cardevent ds
where ds.cardeventdate < t1.cardeventdate
and ds.cardno = t1.cardno
)
Из приведенного выше запроса предыдущая строка отображается отлично
Ожидаемый результат
PERSONID CARDEVENTDATE LastCARDEVENTDATE
5008 20090809 20090805
3405 20090809 20090805
3010 20080810 20080806
Но если в приведенном выше запросе используются групповые, упорядоченные подзапросы, это не займет много времени, так как производительность при большом количестве данных очень плоха
Так может ли кто-нибудь помочь мне найти лучшее решение для такой проблемы?
или любой другой запрос справки?