| 
 | 
| 
 
Sybase declare cursor 
 | 
|||
|---|---|---|---|
| 
 #18+ 
    
  Объясните мне, почему DECLARE CURSOR must be the only statement in the batch. Я не могу с этим смириться. Что, для каждого случая создавать процедуру? или как? Пример: надо удалить для всех подразделений(таблица tDep, поле DepId) всех работников(таблица tStaff, поля StaffId, DepId). Удаление производится процедурой Staff_Del(StaffId). Хочу, чтобы это выглядело так: declare DepCursor cursor for select DepId from tDep go declare @DepId dsIdentifier, @StaffId dsIdentifier open DepCursor fetch DepCursor into @SecId go while (@@sqlstatus = 0) begin declare StaffCursor cursor for select StaffId from tStaff where DepId = @DepId go --??? open StaffCursor fetch StaffCursor into @StaffId while (@@sqlstatus = 0) begin execute Staff_Del @StaffId fetch StaffCursor into @StaffId end close StaffCursor deallocate cursor StaffCursor fetch DepCursor into @DepId end close DepCursor deallocate cursor DepCursor Хочется все это запихнуть в TQuery, но ведь не работает.. Заводить несколько Query не хочется, так как на самом деле запрос сложнее, чем пример, да и вопрос уже принципиальный. А запускать isql - кажется, тоже не пройдет, как он будет цикл разбивать на отдельные batch (go)? Что делать? ...  | 
|||
| 
 : 
 Нравится:
      
  Не нравится:
      
  
   | 
|||
| 06.11.2002, 12:16 | 
  
  
  
   | 
||
| 
 
Sybase declare cursor 
 | 
|||
|---|---|---|---|
| 
 #18+ 
    
  с ентим просто бороться нужно просто придерживаться следующего правила:) declare c cursor for .... go --!!!!!!!!!!!!!!! (объявление всех переменных и тому подобное) open c ---------- close c deallocate cursor c и все, никаких процедур go используеться только один раз для объявления глобальной переменной) ...  | 
|||
| 
 : 
 Нравится:
      
  Не нравится:
      
  
   | 
|||
| 06.11.2002, 15:42 | 
  
  
  
   | 
||
| 
 
Sybase declare cursor 
 | 
|||
|---|---|---|---|
| 
 #18+ 
    
  Даже если курсор, в смысле, запрос зависит от переменной? declare StaffCursor cursor for select StaffId from tStaff where DepId = @DepId Бежим по одной таблице и в зависимости от записи формируем запрос из другой таблицы. А Query вообще go за человека не считает... ругается. ...  | 
|||
| 
 : 
 Нравится:
      
  Не нравится:
      
  
   | 
|||
| 06.11.2002, 16:13 | 
  
  
  
   | 
||
| 
 | 

start [/forum/topic.php?fid=55&fpage=136&tid=2014980]:  | 
    0ms | 
get settings:  | 
    10ms | 
get forum list:  | 
    12ms | 
check forum access:  | 
    3ms | 
check topic access:  | 
    3ms | 
track hit:  | 
    43ms | 
get topic data:  | 
    11ms | 
get forum data:  | 
    2ms | 
get page messages:  | 
    36ms | 
get tp. blocked users:  | 
    1ms | 
| others: | 232ms | 
| total: | 353ms | 

| 0 / 0 | 

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