|
|
|
ASA902. Оптимизация запроса
|
|||
|---|---|---|---|
|
#18+
Может кто-нибудь помочь с такой проблемой. Есть таблицы tb, tb_tmp. Структура идентична, id_str уникально, не формируется как PK, переносится в tb_tmp с остальными данными. Данные закачиваются в tb_tmp из файла и потом инсертом вставляются в tb. Проблема в том, что в tb после инсерта надо заполнить поле tp. Это поле показывает, что следующая запись (по полям dat, id_material) в tb будет с отрицательным полем kol. Кроме как заполнять циклом по всей таблице tb_tmp ничего не придумал. Но это очень медленно. Есть ли возможность ускорить? Код: sql 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12. 13. 14. 15. Код: sql 1. 2. 3. 4. 5. 6. 7. 8. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 24.05.2014, 01:26 |
|
||
|
ASA902. Оптимизация запроса
|
|||
|---|---|---|---|
|
#18+
Повесь триггер на tb. Пусть он обновляет поле с нарастающим итогом как нужно. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 24.05.2014, 06:39 |
|
||
|
ASA902. Оптимизация запроса
|
|||
|---|---|---|---|
|
#18+
White OwlПовесь триггер на tb. Пусть он обновляет поле с нарастающим итогом как нужно. Попробовал, по времени не получилось быстрее. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 24.05.2014, 16:08 |
|
||
|
ASA902. Оптимизация запроса
|
|||
|---|---|---|---|
|
#18+
Если поле ID уникально, создайте по нему первичный ключ, а также поэкспериментируйте с индексами по полям dat и id_material ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 24.05.2014, 17:11 |
|
||
|
ASA902. Оптимизация запроса
|
|||
|---|---|---|---|
|
#18+
а так ли нужен курсор ? может через lateral одним запросом ? begin declare local temporary table tb( ID integer, DAT date, ID_material integer, KOL decimal (17,5), TP integer ); declare local temporary table tb_tmp( ID integer, DAT date, ID_material integer, KOL decimal (17,5), TP integer ); update tb set tp=1 where tb.id in ( select C.id from tb A join tb_tmp B on A.id=B.id, lateral(select first C.id from tb C where C.dat<A.dat and C.id_material=A.id_material order by C.dat desc,C.id) C where B.kol<0 and C.id is not null); commit; end ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 05.08.2014, 07:46 |
|
||
|
|

start [/forum/topic.php?fid=55&msg=38650976&tid=2009830]: |
0ms |
get settings: |
7ms |
get forum list: |
12ms |
check forum access: |
3ms |
check topic access: |
3ms |
track hit: |
152ms |
get topic data: |
11ms |
get forum data: |
3ms |
get page messages: |
43ms |
get tp. blocked users: |
2ms |
| others: | 243ms |
| total: | 479ms |

| 0 / 0 |

Извините, этот баннер — требование Роскомнадзора для исполнения 152 ФЗ.
«На сайте осуществляется обработка файлов cookie, необходимых для работы сайта, а также для анализа использования сайта и улучшения предоставляемых сервисов с использованием метрической программы Яндекс.Метрика. Продолжая использовать сайт, вы даёте согласие с использованием данных технологий».
... ля, ля, ля ...