请教一个存储过程中事务处理问题?
tmpx 2005-05-23 03:33:43 测试环境是在一个同一服务器上的同一数据库中进行的,出错信息如下:
“该操作未能执行,因为 OLE DB 提供程序 'SQLOLEDB' 无法启动分布式事务。
[OLE/DB provider returned message: 不能在指定的事务处理器中获得新事务。”
怀疑错误出现原因在“OPENROWSET”上,数据处理的结果是正确的。
请教应该如何写才不会出现这个出错信息???
测试过程如下:
create PROCEDURE test @sname varchar(30),@username varchar(30),@password varchar(30),@tablename varchar(200)
as
declare @ls_sql varchar(1000)
begin tran t1
delete from txl
set @ls_sql = 'select * into txl FROM OPENROWSET('''+'SQLOLEDB'''+','''+@sname+''';'''+
@username+''';'''+@password+''','+'''SELECT * FROM '+@tablename+'.dbo.txl1'')'
exec (@ls_sql)
commit tran t1
go
下面是测试调用:
declare @sname varchar(30),@username varchar(30),@password varchar(30),@tablename varchar(200)
set @sname='caixp'
set @username = 'sa'
set @password = ''
set @tablename = 'xzdxpt'
EXEC test @sname, @username, @password,@tablename