Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2002.05.30;
Скачать: CL | DM;

Вниз

Переменные в имени таблице (... FROM @myvar)   Найти похожие ветки 

 
AndyM   (2002-05-10 15:23) [0]

Hi ALL!!!
Вот такой вопросик мне нужно организовать примерно вот что:
в хранимую процедуру передается имя таблицы (в переменную @table_name).
в теле процедуры предположим это:

DECLARE @max_id tid
SELECT @max_id = MAX(Id) FROM @table_name

и далее мне нужно в зависимости от значения @max_id что то сделать.
как это можно реализовать??? ведь нельзя в имени таблицы указывать переменную.

пробовал: EXEC("SELECT @max_id = MAX(Id) FROM "+@table_name)
говорит нет переменной @max_id
тогда: EXEC("DECLARE @max_id bigint SELECT @max_id = MAX(Id) FROM "+@table_name)
работает... но нельзя получить значение переменной @max_id...


 
Delirium ©   (2002-05-10 16:17) [1]

сделай так :

DECLARE @max_id bigint
select @max_id=Max_Id
from OpenQuery(LocalServer,"SELECT MAX(Id) as Max_ID FROM "+@table_name)

где LocalServer - liked server сам к себе


 
AndyM   (2002-05-10 16:48) [2]

т.е. если мой сервер называется AAA
то как сделать LocalServer?
EXEC sp_addlinkedserver @server="LocalServer", @srvproduct="", @provider="SQLOLEDB", @datasrc="AAA"
так?


 
Delirium ©   (2002-05-10 17:11) [3]

Можно и так, а если не уверен - Enterprise Manager -> Security -> Linked Servers



Страницы: 1 вся ветка

Текущий архив: 2002.05.30;
Скачать: CL | DM;

Наверх




Память: 0.47 MB
Время: 0.012 c
3-97138
Iris
2002-05-03 09:20
2002.05.30
Вопрос связанный с БД


7-97433
tester
2002-03-06 12:19
2002.05.30
работа с SUBST дисками


4-97459
[HDD]John
2002-03-28 13:52
2002.05.30
Исправляюсь: имитация нажати КЛАВИШИ ТАВ


14-97385
SPeller
2002-04-18 08:44
2002.05.30
Проблема с Виндой


1-97227
Maloy
2002-05-20 14:18
2002.05.30
Использование Ворда для генерации отчетов