Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Начинающим";
Текущий архив: 2009.10.18;
Скачать: [xml.tar.bz2];

Вниз

checksum   Найти похожие ветки 

 
Sergey2   (2009-08-13 17:05) [0]

Есть таблица в которой 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)

ну никак не выполняется.


 
Ega23 ©   (2009-08-13 17:08) [1]

Индекс на это поле наложи.


 
Павел Калугин ©   (2009-08-14 00:01) [2]

1. вместо
> (getdate() - 30)

dateadd(dd,-30,getdate())

2. что получить то надо? данные за период?
если так то накой черт checksum? смотрел что он возвращает?
а план 1-го запроса смотрел? где тормозит?
совет
> [1] Ega23 ©   (13.08.09 17:08)



Страницы: 1 вся ветка

Форум: "Начинающим";
Текущий архив: 2009.10.18;
Скачать: [xml.tar.bz2];

Наверх





Память: 0.44 MB
Время: 0.005 c
15-1250525904
sanx
2009-08-17 20:18
2009.10.18
Где скачать FastMove?


2-1250488501
guest
2009-08-17 09:55
2009.10.18
Word, Excel - многостраничные отчеты по шаблонам


2-1250321330
Киря
2009-08-15 11:28
2009.10.18
Кто может напомнить...


1-1219595805
dmitry_12_08_73
2008-08-24 20:36
2009.10.18
Компоненты, обладающие настраиваемой прозрачностью


2-1250248366
Dymok
2009-08-14 15:12
2009.10.18
Как автоматически ставить пробел после запятой





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский