Этот баннер — требование Роскомнадзора для исполнения 152 ФЗ.
«На сайте осуществляется обработка файлов cookie, необходимых для работы сайта, а также для анализа использования сайта и улучшения предоставляемых сервисов с использованием метрической программы Яндекс.Метрика. Продолжая использовать сайт, вы даёте согласие с использованием данных технологий».
Политика конфиденциальности
|
|
|
cursor dynamic scroll ...for update
|
|||
|---|---|---|---|
|
#18+
Кто сталкивался с таким? SQLServer 2000. В таблице 34046 записей. Хочу вставить в определенное поле типа INT инкрементное значение (1,2,3...). Делаю так declare CUR_FSCORE cursor local dynamic scroll for select PTR from [dbo].[FSCORE] for update open CUR_FSCORE declare @PTR1 int declare @PTR int set @PTR = 1 fetch first from CUR_FSCORE into @PTR1 while (@@fetch_status<>-1) begin update [FSCORE] set ADDR_PTR=@PTR where current of CUR_FSCORE fetch next from CUR_FSCORE into @PTR1 set @PTR=@PTR+1 end close CUR_FSCORE deallocate CUR_FSCORE GO выполняю как скрипт в Query Analizer. Доходит до 32793 шага и из цикла WHILE не выходит и до конца записи не отрабатывает (34046). Очень похоже на переполнение переменной SMALLINT, но у меня такой нет ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 23.07.2001, 10:38 |
|
||
|
cursor dynamic scroll ...for update
|
|||
|---|---|---|---|
|
#18+
Да напишите Вы так declare @PTR int set @PTR = 1 update [FSCORE] set ADDR_PTR=@PTR, @PTR=@PTR+1 и забудьте про курсоры ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 23.07.2001, 12:27 |
|
||
|
|

start [/forum/topic.php?fid=46&msg=32010108&tid=1826116]: |
0ms |
get settings: |
6ms |
get forum list: |
11ms |
check forum access: |
3ms |
check topic access: |
3ms |
track hit: |
30ms |
get topic data: |
7ms |
get forum data: |
2ms |
get page messages: |
27ms |
get tp. blocked users: |
1ms |
| others: | 256ms |
| total: | 346ms |

| 0 / 0 |
