Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2004.05.30;
Скачать: CL | DM;

Вниз

Что происходит с открытым курсором, если очистить "его" таблицу?   Найти похожие ветки 

 
Курдль ©   (2004-05-04 20:21) [0]


begin
 declare CNTR_CURSOR cursor for select * from CNTR_TABLE;
 open CNTR_CURSOR;
 delete from CNTR_TABLE;
 CNTR_LOOP:
 loop
   fetch next CNTR_CURSOR into ...;
   --Если конец набора данных - покинуть петлю
   if sqlstate = "02000"
     then leave CNTR_LOOP;
     message "нет ни одной записи" to log;
   end if;
   message "обработана запись" to log;
 end loop CNTR_LOOP;
 close CNTR_CURSOR;
end;

Если выделенная строка отсутствует, лог выглядит так:
обработана запись
обработана запись
....
обработана запись


Если выделенная строка присутствует:
нет ни одной записи
Что выходит? Изменения в "управляющей таблице(-ах)" после открытия курсора ведут к необратимым изменениям набора данных, которые принял курсор?  :(


 
Andriy Tysh ©   (2004-05-05 10:10) [1]

В MS SQL есть Dynamic и Static курсоры. Первый - реагирует на какие-либо изменеия в своём наборе данных если изменение произошло в том месте, куда он ещё не дошёл, второй делает "фотку" и далее его ничего не тревожит.


 
Курдль ©   (2004-05-05 10:13) [2]

А можно навскидочку весь синтаксис (у меня Sybase, но попробую применить, или хоть доку порыть в нужном направлении). Но вообще-то это странно - нафиг он нужен такой "динамический"?..


 
Andriy Tysh ©   (2004-05-05 10:28) [3]

Нет под рукой у меня хелпа. Но парень, который раньше работал с нами, тоже писал под Sybase. В его процедурах точно был динамический курсор. Нафиг он ему был нужен в тех местах, где он его использует - мы до сих пор не понимаем. Я всегда использую статический. Но это зависит от задачи. Если я выбираю к примеру названия и коды товаров, то предполагаю, что эти два поля точно за 0.0001 секунду никто не изменит. (:-)
Поэтому и не напрягаюсь.


 
Курдль ©   (2004-05-05 10:33) [4]


> Если я выбираю к примеру названия и коды товаров, то предполагаю,
> что эти два поля точно за 0.0001 секунду никто не изменит.
> (:-)
> Поэтому и не напрягаюсь.

У меня задача, в которой без вмешательства не обойтись - курсор строится по 2-м таблицам, связанным по внешнему ключу. Причем, чтобы что-то удалить из второй - надо сначала зачистить первую.



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

Текущий архив: 2004.05.30;
Скачать: CL | DM;

Наверх




Память: 0.48 MB
Время: 0.149 c
6-1081854524
Steelator
2004-04-13 15:08
2004.05.30
Какой лучше использовать Stream для работы с TIdTCPServer/Client


4-1081936017
human
2004-04-14 13:46
2004.05.30
Время простоя ПК


3-1083740118
Alex_2004
2004-05-05 10:55
2004.05.30
Алгоритм заполнения TreeView из БД


6-1081497901
bykopor
2004-04-09 12:05
2004.05.30
Программная шара!!! NetShareAdd


3-1083681273
tlan
2004-05-04 18:34
2004.05.30
RecordSet из DLL