![]() |
Модераторы: Akina |
![]() ![]() ![]() |
|
Wanderer2019 |
|
|||
![]() Опытный ![]() ![]() Профиль Группа: Участник Сообщений: 937 Регистрация: 3.12.2004 Где: Санкт-Петербург/П рага Репутация: нет Всего: 17 |
Привет!
Подскажите как решить 2 проблеммы связанные с хранимой процедурой: 1. Динамически подставлять название сервера и БД в запрос. 2. Возвращать 2 параметра из этой процедуры. По п.1 решением может быть составление теката запроса в формата (например) varchar и далее вызов запроса при помощи EXEC(x). Но вот п.2 никак решить не получается... если пишу, что в нем присвоение данных каким то переменным (в тексте), то при вызове он пишет, что необходимо объявить переменные, хотя они конечно же объявлены. |
|||
|
||||
AlexxxM |
|
|||
Новичок Профиль Группа: Участник Сообщений: 17 Регистрация: 15.5.2007 Репутация: нет Всего: нет |
Да была такая проблема, в динамическом запросе MSSQL не видит внешние переменные.
Решили с помощью временных таблиц, перед выполнением динамического запроса создаем временную таблицу (ее в динамическом запросе видно), записываем нужные данные во временную таблицу, а после выполнения динамического запроса извлекаем данные из временной таблицы |
|||
|
||||
Wanderer2019 |
|
|||
![]() Опытный ![]() ![]() Профиль Группа: Участник Сообщений: 937 Регистрация: 3.12.2004 Где: Санкт-Петербург/П рага Репутация: нет Всего: 17 |
||||
|
||||
Servena |
|
|||
![]() Опытный ![]() ![]() Профиль Группа: Участник Сообщений: 251 Регистрация: 24.7.2007 Где: Днепропетровск Репутация: 10 Всего: 14 |
А пример можно?
|
|||
|
||||
AlexxxM |
|
|||
Новичок Профиль Группа: Участник Сообщений: 17 Регистрация: 15.5.2007 Репутация: нет Всего: нет |
Что-то вроде такого. Временные таблицы создаются также как и обычные таблицы, перед именем таблицы ставится символ #, он и указывает серверу что это временная таблица. DROP TABLE можно не делать, таблица сама уничтожиться по окончании сторед процедуры. Вообще это и в helpе вполне понятно описано. |
|||
|
||||
VOS |
|
|||
Шустрый ![]() Профиль Группа: Участник Сообщений: 145 Регистрация: 31.1.2007 Репутация: 2 Всего: 8 |
Через таблицы можно если Вам надо получить набор данных. Если только пару значений, то лучше так:
|
|||
|
||||
Todd |
|
|||
Новичок Профиль Группа: Участник Сообщений: 11 Регистрация: 14.3.2006 Где: Одесса Репутация: нет Всего: нет |
А если динамический запрос должен возвратить xml?
|
|||
|
||||
![]() ![]() ![]() |
Правила форума "MS SQL" | |
|
Запрещается! Публиковать ссылки и обсуждать взлом чего бы то ни было.
Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, Zloxa, Akina. |
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей) | |
0 Пользователей: | |
« Предыдущая тема | MS SQL Server | Следующая тема » |
|
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности Powered by Invision Power Board(R) 1.3 © 2003 IPS, Inc. |