SQLSERVER分布式事务使用实例

2023年 4月 18日 25.8k 0

复制代码 代码如下: --BEGIN DISTRIBUTED TRANSACTION [transactionname] --标志一个由分布式事务处理协调器MSDTC管理的TSQL分布式事务开始 --SERVER A服务器为主控服务器。当连接发出后续COMMIT TRANSACT

复制代码 代码如下:--BEGIN DISTRIBUTED TRANSACTION [transactionname]--标志一个由分布式事务处理协调器MSDTC管理的TSQL分布式事务开始--SERVER A服务器为主控服务器。当连接发出后续COMMIT TRANSACTION或--ROLLBACK TRANSACTION语句时,主控服务器请求MSDTC在所涉及的服务器间管理--分布式事务的完成

--SQLSERVER使用链接服务器或者远程服务器作为分布式事务处理的平台,提供--远程存储过程调用和分布式查询

--当使用分布式事务进行一个远程存储过程调用和一个分布式查询时,在SERVER A--上发出BEGIN DISTRIBUTED TRANSACTION ,该连接调用SERVER B上的存储过程--和SERVER C上的另一个存储过程,并且SERVER C上的存储过程对SERVER D执行一个--分布式查询,则四个SQLSERVER服务器进入分布式事务中,SERVER A是该事务的创建者--和控制服务器

--创建分布式事务,在本地和远程数据库同时删除一条记录,其中,远程SQLSERVER--的实例名称为RemoteServer。本地和远程数据库同时提交或同时回滚该事务。--注意,执行分布式查询或调用存储过程时,使用4部分名称限定规则

--前提:本机的MSDTC和远程机器的MSDTC服务要打开--本机和远程机器能互相ping通--数据库端口能互相telnet通--创建一个链接服务器到远程机器WIN7U-20130414Z USE [GPOSDB]GOSELECT * FROM [SystemPara] WHERE [Name]='HDTPort'SELECT * FROM [WIN7U-20130414Z].[GPOSDB].dbo.[SystemPara] WHERE [Name]='HDTPort'

 

USE [GPOSDB]GOBEGIN DISTRIBUTED TRANSACTION--从本地数据库删除一条记录DELETE FROM [JOE].[GPOSDB].[DBO].[SystemPara]WHERE [Name]='HDTPort'

--从远程数据库中删除一条记录DELETE FROM [GPOSDB].[dbo].[SystemPara]WHERE [Name]='HDTPort'

COMMIT TRANGO

--个人尝试了下是由于在双向的sql server访问中采用了链式方式访问(LinkedServer方式),--遇到这种情况只需要将原来访问对方数据库的语句:--select  *  from  linkedServerA.dbo.table1--修改为:--select  *  from  dbo.table1即可。--标记下,以便以后解决。

相关文章

Oracle如何使用授予和撤销权限的语法和示例
Awesome Project: 探索 MatrixOrigin 云原生分布式数据库
下载丨66页PDF,云和恩墨技术通讯(2024年7月刊)
社区版oceanbase安装
Oracle 导出CSV工具-sqluldr2
ETL数据集成丨快速将MySQL数据迁移至Doris数据库

发布评论