powered by simpleCommunicator - 2.0.49     © 2025 Programmizd 02
Форумы / Sybase ASA, ASE, IQ [игнор отключен] [закрыт для гостей] / локальная переменная в курсоре
4 сообщений из 4, страница 1 из 1
локальная переменная в курсоре
    #38792742
еннк
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
Здравствуйте!
как добавить локальную переменную @StartDate в курсор?

Код: sql
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
declare @StartDate datetime
select @StartDate = '2014-09-27'

declare test cursor for
select *
from tbl1
where qDate > @StartDate

union all

select *
from tbl2
where qDate > @StartDate
...
open test
....



пробую добавлять переменную перед курсором
но тогда ее не видно в курсоре
пробовал перед селектом в курсоре
или перед open
тоже ругается - нельзя же совместно с другими операторами использовать declare cursor

смотрел faq - но не увидел
http://www.sql.ru/faq/faq_topic.aspx?fid=248
...
Рейтинг: 0 / 0
локальная переменная в курсоре
    #38792797
Teck
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
Попробуйте так:

Код: sql
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
begin
declare @StartDate datetime
select @StartDate = '2014-09-27'

declare test cursor for
select *
from tbl1
where qDate > @StartDate

union all

select *
from tbl2
where qDate > @StartDate
...
open test
....
end
...
Рейтинг: 0 / 0
локальная переменная в курсоре
    #38792812
Ыzz
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
еннк,

если это будет в хранимой процедуре , то переменная будет доступна.
...
Рейтинг: 0 / 0
локальная переменная в курсоре
    #38793666
Фотография MasterZiv
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
TeckПопробуйте так:

Код: sql
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
begin
declare @StartDate datetime
select @StartDate = '2014-09-27'

declare test cursor for
select *
from tbl1
where qDate > @StartDate

union all

select *
from tbl2
where qDate > @StartDate
...
open test
....
end




Это не оракл, не будет работать.
declare cursor должен быть в отдельном батче.

Это невозможно сделать, потому что локальная переменная будет из предыдущего батча, т.е. уже будет
не видна и удалена из памяти.

Это нужно делать в одной хранимой процедуре, либо можно это делать средствами типа SQSh(ell) , в которых есть переменные клиентской стороны.

Тут ещё можно вставить константу в определение курсора. Это при чём можно делать с помощью таких средств, как SED, M4 и подобных.
...
Рейтинг: 0 / 0
4 сообщений из 4, страница 1 из 1
Форумы / Sybase ASA, ASE, IQ [игнор отключен] [закрыт для гостей] / локальная переменная в курсоре
Целевая тема:
Создать новую тему:
Автор:
Закрыть
Цитировать
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]