一个事务问题

tmpx 2005-05-23 07:34:30
出错信息:
该操作未能执行,因为 OLE DB 提供程序 'SQLOLEDB' 无法启动分布式事务。
[OLE/DB provider returned message: 新事务不能登记到指定的事务处理器中。 ]
OLE DB 错误跟踪[OLE/DB Provider 'SQLOLEDB' ITransactionJoin::JoinTransaction returned 0x8004d00a]。

CREATE PROCEDURE test @sname varchar(30),@username varchar(30),@password varchar(30),@tablename varchar(200)
as
declare @ls_sql varchar(1000)
begin tran t1
drop table tdd
set @ls_sql = 'select * into tdd FROM OPENROWSET('''+'SQLOLEDB'''+','''+@sname+''';'''+
@username+''';'''+@password+''','+'''SELECT * FROM '+@tablename+'.dbo.tdd1'')'
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 = 'killer'
set @tablename = 'zhharbormt'

EXEC test @sname, @username, @password,@tablename
请高手帮忙看看
...全文
88 1 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
1 条回复
切换为时间正序
请发表友善的回复…
发表回复
talantlee 2005-05-23
  • 打赏
  • 举报
回复
直接執行這條語句有問題麼?
select * into tdd FROM OPENROWSET('SQLOLEDB','caixp';'sa';'killer','SELECT * FROM zhharbormt.dbo.tdd1')

27,581

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server 应用实例
社区管理员
  • 应用实例社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧