sqlserver同步后在不重新初始化快照的情况下新增表

       在已有事务复制中,时长需要新增表、索引,这些变更时不会同步到从库中。如果采用默认的设置,每次都需要重新初始化快照,从库重新应用快照和未执行的同步命令,这显然是无法在线上实践的方法。另一种方法是将新增的架构变更新建一个发布订阅,但会造成维护困难,增加出错的几率。
       可以通过设置immediate_sync和allow_anonymous 来实现不重新初始化快照的前提下新增表。
       先看着两个参数的含义:
       immediate_sync:指定每次运行快照代理时是否为发布创建同步文件。 immediate_synchronization 的数据类型为 nvarchar(5),默认值为 FALSE。 如果为 True,表示每次运行快照代理时都创建或重新创建同步文件。 如果快照代理在订阅创建前完成,则订阅服务器可以立即获得同步文件。 新订阅将获取最近一次执行快照代理所生成的最新同步文件。 independent_agent 必须为 true,以便于 immediate_synchronization 为 true。 如果为 False,则仅当有新订阅时,才创建同步文件。 当以增量方式向现有发布添加新项目时,必须为每个订阅调用 sp_addsubscription。 订阅后订阅服务器无法接收同步文件,直到启动并完成快照代理为止。
       allow_anonymous:指定是否可为给定发布创建匿名订阅。 allow_anonymous 的数据类型为 nvarchar(5),默认值为 FALSE。 如果为 True,则 immediate_synchronization 也必须设置为 True。 如果为 False,则表示不允许对该发布创建匿名订阅。
       从定义中看出来,immediate_sync为false时,新的项目(表、存储过程等)可以以增量方式发布,而allow_anonymous必须为false,immediate_sync才能为false。
案列,创建了一个数据库masterdb,创建一张表t: 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在SQL Server中,Stamp初始化是指为中的每一行添加一个唯一的标识符。这个标识符通常是一个自增的整数值,每当向中插入一行数据时会自动递增。Stamp初始化主要用于跟踪记录的增删改操作,方便进行数据的修改和追踪。 要在SQL Server中初始化Stamp,可以按照以下步骤进行操作: 1. 创建:首先,需要创建一个,用于存储需要添加Stamp的数据。 2. 添加Stamp字段:在创建的时候,需要为添加一个字段,用于存储Stamp的值。该字段的数据类型通常为整数类型。 3. 设定自增属性:为了使Stamp字段能够自动递增,需要将该字段的自增属性设置为是。可以使用"IDENTITY"关键字来指定该字段具有自增属性。 4. 初始化Stamp:一旦和字段的设置完成,可以执行插入数据的操作,SQL Server会自动为每一行数据分配一个唯一的Stamp标识符。 例如,假设我们要创建一个名为"Customers"的,其中有一个字段"CustomerID"用于存储Stamp值,可以使用以下SQL语句来实现初始化Stamp: ``` CREATE TABLE Customers ( CustomerID INT IDENTITY(1,1) PRIMARY KEY, CustomerName NVARCHAR(50), Address NVARCHAR(100) ) ``` 在执行以上SQL语句后,再向"Customers"中插入数据时,SQL Server会自动为"CustomerID"字段分配递增的Stamp值。 总之,SQL Server中的Stamp初始化是通过创建和设置字段的自增属性来为数据中的每一行添加一个唯一的标识符。这个过程可以方便地进行数据操作和追踪。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值