Есть таблица в которой 10.000.000 записей. Необходимо выбирать из неё записи по условию фильтрации по полю типа datetime.
declare @currDate datetime
set @currdate = getdate()
declare @priorDate datetime
set @priorDate = (getdate() - 30)
select field1, field2, filldata
from MyTable
where filldata < @currdate and filldata > @priorDate
Возвращается в результате выборки несколько записей. Запрос выполняется секунд 40-50. что очень медленно.
Какие пути решения ? каким образом можно уменьшить время выполнения запроса? почитал про checksum. попробовал.
Получилось примерно следующее.
declare @currDate datetime
set @currdate = getdate()
declare @priorDate datetime
set @priorDate = (getdate() - 30)
select *
from
(select field1, field2, checksum(filldata collate database_default) filldateHash
from MyTable) as mt
where mt.filldateHash < checksum(@currdate) and
mt.filldateHash > checksum(@priorDate)
Запрос то теперь этот быстро выполняется. только вот
where mt.filldateHash < checksum(@currdate) and
mt.filldateHash > checksum(@priorDate)
ну никак не выполняется.