|
|
Регистрация Восстановить пароль |
Повторная активизация e-mail |
Регистрация | Задать вопрос |
Заплачу за решение |
Новые сообщения |
Сообщения за день |
Расширенный поиск |
Правила |
Всё прочитано |
|
|
Опции темы | Поиск в этой теме |
26.05.2014, 13:32 | #1 |
Пользователь
Регистрация: 11.12.2012
Сообщений: 56
|
Создание индекса для ускорения выполнения процедуры (SQL)
Имеется процедура для заполнения таблицы, так же для заполнения одного столбца этой таблицы используются данные из другой таблицы.
Код:
|
26.05.2014, 13:41 | #2 |
Белик Виталий :)
Старожил
Регистрация: 23.07.2007
Сообщений: 57,097
|
Если не секрет почему делаешь фетчем, а не insert into... from select ...
?
I'm learning to live...
|
26.05.2014, 13:49 | #3 |
Старожил
Регистрация: 17.11.2010
Сообщений: 18,922
|
Чуть ускорит
Код:
CLOSE cur_insert_sale перед DEALLOCATE пропущен А так курсор очень медленная штука и очень похоже, что все это можно заменить одним/парочкой запросов на обновление без курсора
Если бы архитекторы строили здания так, как программисты пишут программы, то первый залетевший дятел разрушил бы цивилизацию
|
26.05.2014, 15:06 | #4 |
Пользователь
Регистрация: 11.12.2012
Сообщений: 56
|
Спасибо, все учел, но даже с индексом почему то выполнения запроса не ускорилось, так что я просто вынес update из процедуры и выполнил его отдельно, после заполнения всех остальных полей.
|
26.05.2014, 15:33 | #5 | |
Подтвердите свой е-майл
Регистрация: 29.08.2012
Сообщений: 4,011
|
Цитата:
|
|
26.05.2014, 15:34 | #6 | |
Пользователь
Регистрация: 11.12.2012
Сообщений: 56
|
Цитата:
|
|
26.05.2014, 15:39 | #7 |
Подтвердите свой е-майл
Регистрация: 29.08.2012
Сообщений: 4,011
|
передали на 1 запрос без курсоров и результат тот-же?
|
26.05.2014, 15:44 | #8 | |
Подтвердите свой е-майл
Регистрация: 29.08.2012
Сообщений: 4,011
|
Цитата:
|
|
26.05.2014, 15:48 | #9 |
Пользователь
Регистрация: 11.12.2012
Сообщений: 56
|
Ну да, вынес запрос с update из процедуры, выполнил процедуру, таблица заполнилась, столбец price заполнился NULL значениями, потом отдельно выполнил update и скопировал нужные значения в столбец price. Вроде получилось все верно. Процедура без update выполнялась около 30 сек. Если сделал что-то неверно, тогда подскажите, что я сделал не так?
|
26.05.2014, 15:51 | #10 |
Пользователь
Регистрация: 11.12.2012
Сообщений: 56
|
|
|
Похожие темы | ||||
Тема | Автор | Раздел | Ответов | Последнее сообщение |
Сжатие файлов для ускорения загрузки | Derdemyansky | Общие вопросы C/C++ | 3 | 03.02.2014 18:25 |
Создание макроса для выполнения отчетности в несколько кликов! | polysster | Microsoft Office Excel | 2 | 14.08.2013 23:16 |
дефыйна для ускорения ветора и вообще STL | Kukurudza | Общие вопросы C/C++ | 1 | 29.03.2012 18:34 |
Изменение кода для ускорения движения фигуры. | 7vlad37 | Microsoft Office Excel | 7 | 28.07.2011 14:52 |
Создание процедуры на SQL | Skyline20000 | SQL, базы данных | 0 | 31.03.2009 16:57 |