| 
 | 
| 
 
Сюрприз от курсора... 
 | 
|||
|---|---|---|---|
| 
 #18+ 
    
  db2 11.1 fp2 CREATE OR REPLACE PROCEDURE schema1.proc1 ( ) LANGUAGE SQL DETERMINISTIC NO EXTERNAL ACTION BEGIN ATOMIC DECLARE docid INTEGER; FOR c AS SELECT id c_id, f1 c_f1, f2 c_f2 FROM schema1.t1 DO SELECT id INTO docid FROM NEW TABLE(INSERT INTO schema1.t1(f1, f2) VALUES(c_f1, c_f2)); UPDATE schema1.t2 SET f1 = docid WHERE f1 = c_id; DELETE FROM schema1.t1 WHERE id = c_id; END FOR; END; На t1 триггер на генерацию id. t1 и t2 перед вызовом процедуры локируются. По факту update не 1, а три десятка, курсор отбирает записи по условию (50 тыс из 100-а). А сюрприз заключается в том, что курсор зацикливается и начинает гонять записи по кругу, но не все, а как-то выборочно. Причем на тестовой бд, где никто не работает, курсор повторил около 10% записей и завершился. А на рабочей, которую постоянно дергают, завершения дождаться так и не удалось. ...  | 
|||
| 
 : 
 Нравится:
      
  Не нравится:
      
  
   | 
|||
| 13.02.2018, 15:16 | 
  
  
  
   | 
||
| 
 
Сюрприз от курсора... 
 | 
|||
|---|---|---|---|
| 
 #18+ 
    
  Toshkin, Вы сами себе сюрприз сделали. Если не хотите захватывать курсором новые вставленные записи, то: Код: plaintext 1. Или у вас логика включает то, что вставленные при процессинге курсора записи должны им же опать захватываться? ...  | 
|||
| 
 : 
 Нравится:
      
  Не нравится:
      
  
   | 
|||
| 13.02.2018, 15:42 | 
  
  
  
   | 
||
| 
 
Сюрприз от курсора... 
 | 
|||
|---|---|---|---|
| 
 #18+ 
    
  Mark Barinstein, нет, не должны... я просто не предполагал, что содержимое курсора может меняться в процессе его обработки... ...  | 
|||
| 
 : 
 Нравится:
      
  Не нравится:
      
  
   | 
|||
| 13.02.2018, 15:52 | 
  
  
  
   | 
||
| 
 
Сюрприз от курсора... 
 | 
|||
|---|---|---|---|
| 
 #18+ 
    
  Toshkin, По-умолчанию курсор, как следует из ссылки, ASENSITIVE. Это значит, что если курсор - read-only, то его поведение как у sensitive курсора. Если он не read-only, то - как у insensitive. В вашем запросе - одна таблица и не указано FOR READ ONLY или FOR UPDATE. Т.е. курсор мог быть объявлен как FOR UPDATE, и db2 его так и открывает, скорее всего. Поэтому, если не надо эффекта чтения своих же изменений, то либо как написано выше, либо в SELECT в конце добавить FOR READ ONLY. ...  | 
|||
| 
 : 
 Нравится:
      
  Не нравится:
      
  
   | 
|||
| 13.02.2018, 17:03 | 
  
  
  
   | 
||
| 
 | 

start [/forum/moderation_log.php?user_name=%D0%95%D0%B2%D0%B3%D0%B5%D0%BD%D0%B8%D0%B9_26]:  | 
    0ms | 
get settings:  | 
    10ms | 
get forum list:  | 
    12ms | 
get settings:  | 
    10ms | 
get forum list:  | 
    13ms | 
check forum access:  | 
    4ms | 
check topic access:  | 
    4ms | 
track hit:  | 
    67ms | 
get topic data:  | 
    12ms | 
get forum data:  | 
    2ms | 
get page messages:  | 
    37ms | 
get tp. blocked users:  | 
    2ms | 
| others: | 441ms | 
| total: | 614ms | 

| 0 / 0 | 

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