SQL Server数据库同步问题

  我们可以通过数据复制跨局域网、Internet在不同的数据库服务器上面维护多个数据的多个拷贝,同时以同步或异步的方式保证各个拷贝之间的数据一致性。

  SQL Server提供完善的内置数据复制能力,它是SQL Server核心引擎非常重要的一部分。

  SQL Server的复制分为三种方式:

  快照复制:在某个时间点对于出版数据库中的数据照相,然后将其复制到定购服务器上。一般用于复制静态表。

  事务复制:复制的内容是多条语句和存储过程,这样定购数据库只是读取数据库的数据修改方式,并且反映这种修改。一般用户更新频率较高的数据库。

  合并复制:允许定购者和出版者的双向修改,并将修改反映到双方数据库上。如果数据有冲突,将会按照一定规则处理该冲突。

  目前单位有用到一个web网站,数据库分别位于美国,荷兰和深圳。在网站基础架构上,我们使用的是3DNS和BigIP实现智能域名解析和负载均衡。但由于三地具备各自的数据库(SQL Server),需要保证各个数据库的数据一致。我们就需要做数据复制。根据用户的要求我们做的是事务复制,在网站的前两个版本都很正常,但在上两周更新了web页面版本后,发现事务复制经常出现错误。重新做事务复制在间隔不长的时间后仍然出现。后检查错误日志发现提示:

  The query processor could not produce a query plan from the optimizer because a query cannot update a text, ntext, or image column and a clustering key at the same

  检查数据库表格,经过排查,确定存在问题的一个表格(XXX_article)。和程序员确认后发现此表格属性变更为ntext类型,而且会同时更新此字段和此表的聚集索引栏位。

  因此,怀疑是由于在做事务复制时会同时修改这两处位置造成,查阅相关的数据未能找到明确的官方说明,但是有其他程序的人员在程序编码中发现类似问题,其解决方法是分成两次update这个两个栏位。具体的技术细节,未能得到明确的说明。在事务复制上我们无法干扰其过程,因此我们将不对xxx_article做事务复制。然后对于xxx_article做快照复制,这样可以避免此问题的产生。经过测试和应用,此问题已经得到解决。

时间: 2024-11-03 06:29:16

SQL Server数据库同步问题的相关文章

SQL Server数据库同步问题分享(二)---操作步骤[未完,待续]

    SQL Server数据库同步问题分享[未完,待续](一)  SQL Server数据库同步问题分享(二)---操作步骤[未完,待续]  SQL Server数据库同步问题分享(三)---创建订阅        上面的设置自己看着办数据库表中如果有些表字段没有指定发布,则在筛选的时候是不允许的可以使用发布数据库机器作为分发服务器,一般情况我们也是这么做的,当然我们也可以使用其他的机器作为分发服务器,这里就需要自己配置分发服务器这里配置了机器名的映射,可以参考一下 (一) SQLServe

SQL Server数据库同步复制的图解

快照复制:通过设定固定的时间周期 进行复制, 时间周期范围可以任意设置在一分钟到一个月之间, 是三种复制功能中最稳定的. 事物复制:通过实时监测数据库更新, 在每次 更新时对数据和数据库对象进行复制, 实时性能 最好, 但SQL Server个人版本无法提供事物复制功能, 企业版本虽然有该功能, 但不能对数据内容进行筛选, 实用性和稳定性都比快照复制低. 合并复制:指两个数据库之间有任意一个数据库更新 就会使另一个数据库随之更新, 安全性差, 通常较少使用. 服务器端配置: 1.新建共享目录 将

sql server 数据库同步的问题

问题描述 开发会员软件连锁店版用sqlserver复制功能发布订阅来同步数据库但是中间需要60秒的延时插入一条数据或者修改一条数据需要1分钟后才可以同步这样的话一个店中有多个收银台或者不需要顾客持卡消费就有可能因为数据不同步的原因产生错误.有什么办法可以实时同步吗?各位大神谁开发过这种软件啊?求赐教 解决方案 解决方案二:你作为备份数据可以这样做,但要求高度一致性是不可以这样做的,至少在现有的技术手段下不能,以后肯定能,核心问题就是存在像你这样延时的问题,不要说60秒,有时1毫秒都不行,只能从一

C#同步SQL Server数据库中的数据--数据库同步工具[同步已有的有变化的数据]

C#同步SQL Server数据库中的数据--数据库同步工具[同步已有的有变化的数据] 1. C#同步SQL Server数据库Schema 2. C#同步SQL Server数据库中的数据--数据库同步工具[同步新数据] 3. 分析下自己写的SQL Server同步工具的性能和缺陷 接着写数据同步,这次可以把有变化的数据进行更新了: 1.SQL批量更新函数: /// <summary> /// Note: for columns, the first string must be prima

C#同步SQL Server数据库Schema

C#同步SQL Server数据库Schema 1. 先写个sql处理类: using System; using System.Collections.Generic; using System.Data; using System.Data.SqlClient; using System.Text; namespace PinkDatabaseSync { class DBUtility : IDisposable { private string Server; private strin

C#同步SQL Server数据库中的数据--数据库同步工具[同步新数据]

C#同步SQL Server数据库中的数据 1. 先写个sql处理类: using System; using System.Collections.Generic; using System.Data; using System.Data.SqlClient; using System.Text; namespace PinkDatabaseSync { class DBUtility : IDisposable { private string Server; private string

SQL SERVER 2005同步复制技术的应用

本文以快照复制为例,介绍SQL SERVER 2005同步复制技术的应用. 以下实现复制步骤(以快照复制为例) 运行平台SQL SERVER 2005 一.准备工作: 1.建立一个 WINDOWS 用户,设置为管理员权限,并设置密码,作为发布快照文件的有效访问用户. 2.在SQL SERVER下实现发布服务器和订阅服务器的通信正常(即可以互访).打开1433端口,在防火墙中设特例 3.在发布服务器上建立一个共享目录,作为发布快照文件的存放目录.例如:在D盘根目录下建文件夹名为SqlCopy 4.

VFP中用SPT访问SQL Server数据库

VFP因它简单易学,可快速建立应用软件而深受广大程序员喜爱,但其数据库系统不安全也令广大用户非常头痛.随着MS SQL Server数据库系统的推广应用,其强大的安全性能普遍受到好评.笔者在长期的编程实践中,发现利用VFP的SQL pass-through(SPT)技术结合MS SQL Server数据库系统,也能像VB.Delphi.PowerBuilder一样轻松开发出优秀的客户/服务器(C/S)应用软件.现通过编写一个简单的通信录例子和广大VFP爱好者共同探讨. 一.服务器端MS SQL

Windows 集成的身份验证连接SQL Server数据库,打造更安全的连接

server|window|安全|数据|数据库 摘要:今天用C#编写一个Windows 服务程序,其中要连接一个Windows 2003 Server上的SQL Server 2000 数据库,用SQL Server 身份验证.发现普通程序都能联上,但是Windows服务程序就是联不上. 后来查了资料,找到了解决方法.共享给大家. 三步解决: 1.  在服务器上创建一个用户,配置好SQL Server数据库访问权限. 2.  在客户端创建一个一样的用户. 3.  服务程序以刚创建的那个客户端用户