Главная страница
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.008 c
3-97156
vne
2002-05-03 17:55
2002.05.30
Select из Query без сохранения на диск


14-97413
BigBadMutuh
2002-04-21 14:02
2002.05.30
Как живётся программистам?


1-97271
SergLight
2002-05-18 15:13
2002.05.30
Динамическое создание компонента


1-97276
masik
2002-05-17 14:44
2002.05.30
RichEdit to HTML


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