订阅发布常见问题

基础配置

常见问题

机器名和数据库名不一致

  1. 检查名称
use master
go
select @@servername
select serverproperty('servername')
  1. 配置计算机名与服务名一致
USE master
 GO
 if serverproperty('servername') <> @@servername  
begin  
       declare @server sysname  
       set   @server = @@servername  
       exec sp_dropserver @server = @server  
       set   @server = cast(serverproperty('servername') as sysname)  
       exec sp_addserver @server = @server , @local = 'LOCAL'  
end
  1. 重启数据库

使用过程

常见问题

数据不一致

  1. 查询当前报错事务号
sp_helpsubscriptionerrors '发布服务器名称'
, '发布数据库名称' 
, '发布名称' 
, '订阅服务器名称' 
, '订阅数据库名称'

或者直接查询表MSrepl_commands

  • 字段xact_seqno 表示命令关联的事务,一个事务可能关联一个或多个Command,
  • 字段 command_id 表示在事务中每个Command的ID值;
  • 字段 command 存储SQL Server的command,数据类型是varbinary(1024);

初略查看待执行的语句

SELECT CAST(SUBSTRING(command, 7, 8000) AS NVARCHAR(MAX))
FROM dbo.msrepl_commands
WHERE xact_seqno = 0x0008E9340005C068003E

查看详细的语句

sys.sp_browsereplcmds  '开始事务号' ]'结束事务号' ] 
  1. 处理报错事务号
  • 直接跳过事务号 (我自己尝试没成功)
sp_setsubscriptionxactseqno  '发布服务器主机名'
, '发布数据库'
,  '发布名称'
,  跳过的事务号
  • 或者直接删除MSrepl_commands表的数据 (我自己尝试成功)
delete MSrepl_commands where xact_seqno = 跳过的事务号
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值