powered by simpleCommunicator - 2.0.60     © 2026 Programmizd 02
Целевая тема:
Создать новую тему:
Автор:
Закрыть
Цитировать
Форумы / Sybase ASA, ASE, IQ [игнор отключен] [закрыт для гостей] / Вопрос по create existing table
10 сообщений из 10, страница 1 из 1
Вопрос по create existing table
    #33805197
Михаил_Sybase
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
Есть необходимость использовать инструкцию create existing table с переменным значением пути к таблице.
Стандартная конструкция работает:
create existing table owner.tablename at 'server;path;;table'

а вот такая:

declare @pathvar char
set @pathvar = 'server;path;;table';
create existing table owner.tablename at @pathvar

ругается на @pathvar.
Есть ли способ заставить ее принимать переменную в качестве пути?
...
Рейтинг: 0 / 0
Вопрос по create existing table
    #33806051
Фотография ASCRUS
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Такие вещи легко делаются через сборку запроса в строкву, с подстановкой уже самих значений с переменных и выполнения строки через динамический SQL.
--
www.rusug.ru - портал русскоязычной группы пользователей Sybase
...
Рейтинг: 0 / 0
Вопрос по create existing table
    #33808785
polexm
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Добрый день!
Не всегда удобны динамические запросы, особенно на этапе сопровождения готового программного продукта.

Я тоже столкнулся с проблемой:
к примеру, имеем запрос, который работает в MS SQL:

Код: plaintext
1.
2.
3.
4.
5.
declare @a int
set @a = :a
select q from X where c = @a
union
select q from Y where c = @a

в ASA 9.02 он не работает.

Как быть?

Спасибо!
...
Рейтинг: 0 / 0
Вопрос по create existing table
    #33808893
Dim2000
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
polexm wrote:

> к примеру, имеем запрос, который работает в MS SQL:

....

> в ASA 9.02 он не работает.
>
> Как быть?

Вспомнить о том, что ASA - это не M$SQL.
Posted via ActualForum NNTP Server 1.3
...
Рейтинг: 0 / 0
Вопрос по create existing table
    #33808931
polexm
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Что именно нужно вспомнить?
Если возможно - подскажите, пожалуйста, как выйти из этой ситуации?
...
Рейтинг: 0 / 0
Вопрос по create existing table
    #33808953
Фотография ASCRUS
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
polexmДобрый день!
Не всегда удобны динамические запросы, особенно на этапе сопровождения готового программного продукта.

Я тоже столкнулся с проблемой:
к примеру, имеем запрос, который работает в MS SQL:

Код: plaintext
1.
2.
3.
4.
5.
declare @a int
set @a = :a
select q from X where c = @a
union
select q from Y where c = @a

в ASA 9.02 он не работает.

Как быть?

Спасибо!
Такие вещи лучше оформить в виде ХП и вызывать ее как EXEC Proc(@a = :a). Здесь самое удобное будет в том, что даже в случае, когда на ASA и MSSQL решение будет разным с точки зрения синтаксиса или производительности, просто нужно будет для каждого сервера написать свою версию ХП, а клиент будет просто ее вызывать, ничего не зная о различиях на серверах.
...
Рейтинг: 0 / 0
Вопрос по create existing table
    #33808988
polexm
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Спасибо!

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

Каким образом нужно написать указанный выше запрос, чтобы при вызове его из клиентского приложения посредством TQuery, можно было передать значение параметра?

Спасибо!
...
Рейтинг: 0 / 0
Вопрос по create existing table
    #33809018
Фотография Dmitry.
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
если коннектится к аса через TDS (ASE client) то этот запрос должен работать.
...
Рейтинг: 0 / 0
Вопрос по create existing table
    #33809028
Фотография Dmitry.
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
polexmСпасибо!
Каким образом нужно написать указанный выше запрос, чтобы при вызове его из клиентского приложения посредством TQuery, можно было передать значение параметра?


Код: plaintext
1.
2.
select q from X where c = :x_c
union
select q from Y where c = :y_c
...
Рейтинг: 0 / 0
Вопрос по create existing table
    #33809044
polexm
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Спасибо!
...
Рейтинг: 0 / 0
10 сообщений из 10, страница 1 из 1
Форумы / Sybase ASA, ASE, IQ [игнор отключен] [закрыт для гостей] / Вопрос по create existing table
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


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