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

Вниз

Linked Servers - команда, не возвращающая rowset   Найти похожие ветки 

 
Тих   (2003-04-09 21:41) [0]

Надо с MS SQL послать команду прилинкованному Ораклу. Select/Insert выполняются через select from openquery и insert into openquery соответственно, а вот как насчет delete/update и прочих команд?


 
Дмитрий Баранов ©   (2003-04-10 11:24) [1]

Через OLE (тестировано на MS SQL 2000)

SET QUOTED_IDENTIFIER ON
GO
SET ANSI_NULLS ON
GO


CREATE procedure ExecuteRemoteCommand
(
@ConnectionString nvarchar(2000),
@UserId nvarchar(2000),
@Password nvarchar(2000),
@Command nvarchar(4000)
) as
begin

DECLARE @object int;
DECLARE @hr int;
DECLARE @ErrorS int;
DECLARE @Error nvarchar(1000);
EXEC @hr = sp_OACreate "ADODB.Connection", @object OUT;
if (@hr <> 0)
begin
Exec sp_OAGetErrorInfo @object, @ErrorS OUT , @Error OUT;
print @Error;
return;
end;

EXEC @hr = sp_OAMethod @object, "Open", NULL, @ConnectionString, @UserId, @Password, "0";
if (@hr <> 0)
begin
Exec sp_OAGetErrorInfo @object, @ErrorS OUT , @Error OUT;
print @Error;
end

EXEC @hr = sp_OAMethod @object, "Execute", NULL, @Command

if (@hr <> 0)
begin
Exec sp_OAGetErrorInfo @object, @ErrorS OUT , @Error OUT;
print @Error;
end

EXEC @hr = sp_OAMethod @object, "Close"

end


GO
SET QUOTED_IDENTIFIER OFF
GO
SET ANSI_NULLS ON
GO


 
sniknik ©   (2003-04-10 11:46) [2]

если к Ораклу OLE DB драйвера должно работать аналогичное
DELETE FROM OpenDataSource("Microsoft.Jet.OLEDB.4.0", "D:\Base.mdb";"admin";"")...datyear1



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

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

Наверх




Память: 0.47 MB
Время: 0.018 c
11-91239
Vitalis
2002-07-21 12:08
2003.04.28
Графика в KOL


14-91498
Lokk
2003-04-10 15:52
2003.04.28
Народ , у кого нить есть реализация метода прогонки ?????


3-91174
BorisUK
2003-04-09 09:28
2003.04.28
DataSnap сервер (RemoteDateModule) как сервис NT


1-91295
RavenD
2003-04-17 14:56
2003.04.28
Досрочное завершение цикла?


1-91395
Гость
2003-04-16 15:30
2003.04.28
Программное нажатие Print Screen