Главная страница
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.023 c
3-97158
asafr
2002-05-06 17:05
2002.05.30
Переменное название временной таблицы в сохраненной процедуре.


1-97261
VicV
2002-05-17 23:00
2002.05.30
Кто нибудь знает, как сделать отчет в Еxcel?


1-97320
Musicmax
2002-05-19 19:00
2002.05.30
товаришчи! Подсажите как избежать ошибки ....


1-97343
Коля
2002-05-20 04:02
2002.05.30
Как прервать цикл?


1-97333
Sterh1
2002-05-18 20:31
2002.05.30
Files