数据库复制:修改表结构、新增表、新增存储过程 会被复制到订阅服务器

本文涉及的产品
云数据库 RDS SQL Server,基础系列 2核4GB
RDS SQL Server Serverless,2-4RCU 50GB 3个月
推荐场景:
简介:

【SQL Server高可用性】数据库复制:修改表结构、新增表、新增存储过程 会被复制到订阅服务器?


在SQL Server上配置好数据库复制后:

         

         1、如果给表加了字段,会不会复制到订阅服务器呢?如果是删除1个字段呢?

         2、如果新创建了1个表,会不会被同步过去呢?

         3、如果新建了一个存储过程,会不会同步过去呢?


本文将会通过实验,回答上述问题。



1、首先,需要配置数据库复制。

这里为了简单起见,用了机器上的2个SQL Server 2008R2的实例。

两个实例分别是:MSSQLSERVER、SQL2008R2。

在配置时,以MSSQLSERVER为发布服务器,而SQL2008R2为订阅服务器,配置为请求订阅。


详细的配置方法,可以参考这篇文章,区别在于下面的文章中是配置成了推送订阅,有什么不明白的,可以在给我留言:

【SQL Server高可用性】数据库复制:SQL Server 2008R2中通过数据库复制,把A表的数据复制到B表


在两个实例上运行如下代码,来创建数据库和表:

create database w
go

use w
go

create table www(id int primary key ,v varchar(10))


下面是配置完成后的截图:

发布服务器



订阅服务器




2、对于已经发布的表www,增加1列,会自动同步吗?

在发布服务器上运行如下代码:

 

alter table www
add v2 varchar(10)


从订阅服务器的图中,并没有发现www表上新增的v2列,说明没有同步过去,那么这样怎么办呢?



这个时候,尝试“重新初始化订阅”:





这里进行重新初始化,成功了。如果不成功,可以按照弹出的错误窗口的提示,禁用分发代理,然后再次重新初始化订阅就可以了:



再次查看订阅服务器,发现www表,已经有了v2列了:



接下来,在发布服务器上,再增加一个字段,发现订阅服务器也自动增加了这个字段,而不需要重新初始化:

 

alter table www
add v3 datetime




然后,我们在发布服务器上删除v3字段,而订阅服务器上也自动删除了这个v3字段。

但有时候,也会报错,这个时候,可以再次尝试一下,一般就能删除这个字段。


3、新创建了1个表,会不会被同步过去呢?

这个得看是什么表,如果没有主键,那么就没办法复制到订阅服务器了。而如果是有主键的表,就可以复制。


先在发布服务器上创建2个表:

 

--没有主键
select * into abc
from sys.objects


--有主键
create table abc123(a int primary key,b varchar(20),c datetime)


我们发现,在发布服务器上创建表后,和新增、删除列不同,并不会自动复制到订阅服务器上,那么怎么办呢?


其实,很简单,只需要找到发布,然后右键,选择“属性”:



在弹出的框中,在左边选择“项目”,在右边去掉“仅显示列表中已选中的项目”,然后给abc123表打手勾,就可以了,也就是让SQL Server也复制这个表到订阅服务器,否则SQL Server也不知道是否需要复杂:



不过,需要注意的是abc这个表上有一个红色的圈,因为是没有主键,这个表示不能复制的意思。


再次查看订阅服务器,发现表已经同步,而且对每个被同步的表,都会有3个存储过程,分别对应insert、update、delete:



如果没有同步,需要用上面提到的方法,重新初始化一下就可以了。



4、如果新建了一个存储过程,会不会同步过去呢?

其实这个和新建表是一样的,需要在设置发布的属性中的“项目”,把要发布的存储过程,打上勾就可以了。

那如果想修改存储过程呢?

这个一般会自动同步,所以修改后,自动就同步到订阅服务器了。

分类:  SqlServer

本文转自快乐就好博客园博客,原文链接:http://www.cnblogs.com/happyday56/p/3849018.html,如需转载请自行联系原作者
相关实践学习
使用SQL语句管理索引
本次实验主要介绍如何在RDS-SQLServer数据库中,使用SQL语句管理索引。
SQL Server on Linux入门教程
SQL Server数据库一直只提供Windows下的版本。2016年微软宣布推出可运行在Linux系统下的SQL Server数据库,该版本目前还是早期预览版本。本课程主要介绍SQLServer On Linux的基本知识。 相关的阿里云产品:云数据库RDS SQL Server版 RDS SQL Server不仅拥有高可用架构和任意时间点的数据恢复功能,强力支撑各种企业应用,同时也包含了微软的License费用,减少额外支出。 了解产品详情: https://www.aliyun.com/product/rds/sqlserver
相关文章
|
20天前
|
PHP 数据库 数据安全/隐私保护
布谷直播源码部署服务器关于数据库配置的详细说明
布谷直播系统源码搭建部署时数据库配置明细!
|
23天前
|
存储 关系型数据库 MySQL
查询服务器CPU、内存、磁盘、网络IO、队列、数据库占用空间等等信息
查询服务器CPU、内存、磁盘、网络IO、队列、数据库占用空间等等信息
198 2
|
20天前
|
存储 Oracle 关系型数据库
oracle服务器存储过程中调用http
通过配置权限、创建和调用存储过程,您可以在Oracle数据库中使用UTL_HTTP包发起HTTP请求。这使得Oracle存储过程可以与外部HTTP服务进行交互,从而实现更复杂的数据处理和集成。在实际应用中,根据具体需求调整请求类型和错误处理逻辑,以确保系统的稳定性和可靠性。
25 0
|
1月前
|
存储 SQL 关系型数据库
MySql数据库---存储过程
MySql数据库---存储过程
36 5
|
1月前
|
应用服务中间件 PHP Apache
PbootCMS提示错误信息“未检测到您服务器环境的sqlite3数据库扩展...”
PbootCMS提示错误信息“未检测到您服务器环境的sqlite3数据库扩展...”
|
2月前
|
存储 数据挖掘 数据库
服务器数据恢复—raid磁盘故障导致数据库数据损坏的数据恢复案例
存储中有一组由3块SAS硬盘组建的raid。上层win server操作系统层面划分了3个分区,数据库存放在D分区,备份存放在E分区。 RAID中一块硬盘的指示灯亮红色,D分区无法识别;E分区可识别,但是拷贝文件报错。管理员重启服务器,导致离线的硬盘上线开始同步数据,同步还没有完成就直接强制关机了,之后就没有动过服务器。
|
2月前
|
存储 关系型数据库 MySQL
查询服务器CPU、内存、磁盘、网络IO、队列、数据库占用空间等等信息
查询服务器CPU、内存、磁盘、网络IO、队列、数据库占用空间等等信息
148 5
|
1月前
|
SQL 数据库
SQL-serve数据库不能连接本地服务器的解决方案
SQL-serve数据库不能连接本地服务器的解决方案
182 0
|
2月前
|
存储 Oracle 关系型数据库
Oracle同一台服务器创建多个数据库
【8月更文挑战第30天】在 Oracle 中,可在同一服务器上创建多个数据库。首先确保已安装 Oracle 软件并具有足够资源,然后使用 DBCA 工具按步骤创建,包括选择模板、配置存储及字符集等。重复此过程可创建多个数据库,需确保名称、SID 和存储位置唯一。创建后,可通过 Oracle Enterprise Manager 进行管理,注意服务器资源分配与规划。
132 10
|
3月前
|
存储 SQL 安全
【数据库高手的秘密武器:深度解析SQL视图与存储过程的魅力——封装复杂逻辑,实现代码高复用性的终极指南】
【8月更文挑战第31天】本文通过具体代码示例介绍 SQL 视图与存储过程的创建及应用优势。视图作为虚拟表,可简化复杂查询并提升代码可维护性;存储过程则预编译 SQL 语句,支持复杂逻辑与事务处理,增强代码复用性和安全性。通过创建视图 `high_earners` 和存储过程 `get_employee_details` 及 `update_salary` 的实例,展示了二者在实际项目中的强大功能。
42 1
下一篇
无影云桌面