Форум программистов, компьютерный форум, киберфорум
Microsoft SQL Server
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.76/21: Рейтинг темы: голосов - 21, средняя оценка - 4.76
3 / 3 / 6
Регистрация: 31.05.2014
Сообщений: 177

Скорость выполнения запроса

26.07.2017, 09:14. Показов 4074. Ответов 2

Студворк — интернет-сервис помощи студентам
Не могу понять почему медленно выполняется запрос.
T-SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
select distinct
    DATEPART(day,CAST(dateDocument as date)) as dateTax,
    (select 
        COUNT(dr.id) 
    from dataRegistr as dR
        JOIN  newRegistr nR ON  dR.shiftCode = nR.shiftCode and nR.sort = 0 
    WHERE 
        CAST(dR.dateDocument as date) = CAST(dataRegistr.dateDocument as date) 
        and nR.addressCode = (select top 1 addressCode FROM newRegistr where shiftCode = dataRegistr.shiftCode 
        and sort = 0)) as countTrip,
    (select top 1 addressName FROM newRegistr where shiftCode = dataRegistr.shiftCode and sort = 0) as depotName
from dataregistr
where 
    CAST(dateDocument as date) between '2017-06-01' and '2017-06-30' and (select top 1 addressName FROM newRegistr where shiftCode = dataRegistr.shiftCode and sort = 0) is not null 
ORDER by  dateTax ASC
Приведенный запрос выполняется 3:38 секунд, он возвращает 233 строки, количество которое считает COUNT суммарно получается 17 225 шт.

На всех полях участвующих в фильтрах созданы индексы.
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
26.07.2017, 09:14
Ответы с готовыми решениями:

Скорость выполнения запроса и индексирование
Создал базу данных, в ней около 55.000 тысяч записей. Создал запрос, потом создал индекс. Разницы во времени практически не заметил. От...

Приостановка выполнения запроса
Добрый день. В C# есть метод Thread.Sleep, который останавливает выполнения запроса на какое-то время. Если ли аналогичная возможность...

Протокол выполнения запроса
Юзаю SQL Management Studio 2012 Задание: выполнить скрипт внесения данных в базу. Сохранить протокол выполнения в файл. Скрипт...

2
0 / 0 / 1
Регистрация: 21.12.2013
Сообщений: 12
26.07.2017, 09:25
Лучший ответ Сообщение было отмечено Yourasik как решение

Решение

Скорее всего из-за AND'a, в 6 строке
0
3 / 3 / 6
Регистрация: 31.05.2014
Сообщений: 177
26.07.2017, 10:07  [ТС]
Поможет если перенести это в WHERE? Я думал это одно и тоже.

Добавлено через 16 минут
Перенес в WHERE выполнение сократилось до 0:52 секунды
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
26.07.2017, 10:07
Помогаю со студенческими работами здесь

Результат выполнения SQL запроса
Здрасте. не подскажите результат выполнения SQL запроса: Select * from stud, gruppa where stud.sngroup=gruppa.gngroup

Пустой результат выполнения запроса
SELECT d.Description_of_operations, Count(*)as 'kol vo', SUM(t.salary + t.Rise) as 'summarnaya' FROM History_disease f, Operation d,...

Анализ выполнения sql запроса
В моем проекте настало время оптимизировать запросы. Но тут же и появилась проблема я не знаю как это делается, не иструменты какие нужно...

Остановка выполнения запроса по условию
Здравствуйте, форумчане. пишу большую хранимую процедуру для сборки данных по таблицам, в самом начале проверяю ошибки следующим запросом ...

Процесс выполнения запроса
Можно ли проследить выполнение запроса? Типа set rs = db.execute('Select *...'), как он выполняется по стадиям?


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Фото всей Земли с борта корабля Orion миссии Artemis II
kumehtar 04.04.2026
Это первое подобное фото сделанное человеком за 50 лет. Снимок называют новым вариантом легендарной фотографии «The Blue Marble» 1972 года, сделанной с борта корабля «Аполлон-17». Новое фото. . .
Вывод диалогового окна перед закрытием, если документ не проведён
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать программный контроль на предмет проведения документа. . .
Программный контроль заполнения реквизита табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать контроль заполнения реквизита "ПричинаСписания". . .
wmic не является внутренней или внешней командой
Maks 02.04.2026
Решение: DISM / Online / Add-Capability / CapabilityName:WMIC~~~~ Отсюда: https:/ / winitpro. ru/ index. php/ 2025/ 02/ 14/ komanda-wmic-ne-naydena/
Программная установка даты и запрет ее изменения
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: при создании документов установить период списания автоматически. . .
Вывод данных в справочнике через динамический список
Maks 01.04.2026
Реализация из решения ниже выполнена на примере нетипового справочника "Спецтехника" разработанного в конфигурации КА2. Задача: вывести данные из ТЧ нетипового документа. . .
Программное заполнения текстового поля в реквизите формы документа
Maks 01.04.2026
Алгоритм из решения ниже реализован на нетиповом документе "ВыдачаОборудованияНаСпецтехнику" разработанного в конфигурации КА2, в дополнении к предыдущему решению. На форме документа создается. . .
К слову об оптимизации
kumehtar 01.04.2026
Вспоминаю начало 2000-х, университет, когда я писал на Delphi. Тогда среди программистов на форумах активно обсуждали аккуратную работу с памятью: нужно было следить за переменными, вовремя. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru