Новые сообщения [новые:0]
Дайджест
Горячие темы
Избранное [новые:0]
Форумы
Пользователи
Статистика
Статистика нагрузки
Мод. лог
Поиск
|
06.11.2002, 12:16
|
|||
---|---|---|---|
|
|||
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, 15:42
|
|||
---|---|---|---|
|
|||
Sybase declare cursor |
|||
#18+
с ентим просто бороться нужно просто придерживаться следующего правила:) declare c cursor for .... go --!!!!!!!!!!!!!!! (объявление всех переменных и тому подобное) open c ---------- close c deallocate cursor c и все, никаких процедур go используеться только один раз для объявления глобальной переменной) ... |
|||
:
Нравится:
Не нравится:
|
|||
|
06.11.2002, 16:13
|
|||
---|---|---|---|
|
|||
Sybase declare cursor |
|||
#18+
Даже если курсор, в смысле, запрос зависит от переменной? declare StaffCursor cursor for select StaffId from tStaff where DepId = @DepId Бежим по одной таблице и в зависимости от записи формируем запрос из другой таблицы. А Query вообще go за человека не считает... ругается. ... |
|||
:
Нравится:
Не нравится:
|
|||
|
|
start [/forum/search_topic.php?author=simplefeel&author_mode=last_topics&do_search=1]: |
0ms |
get settings: |
8ms |
get forum list: |
15ms |
get settings: |
8ms |
get forum list: |
14ms |
check forum access: |
4ms |
check topic access: |
4ms |
track hit: |
579ms |
get topic data: |
12ms |
get forum data: |
2ms |
get page messages: |
47ms |
get tp. blocked users: |
2ms |
others: | 571ms |
total: | 1266ms |
0 / 0 |