乐观 发表于 2015-1-16 22:37:44

MSSQL教程之使用数据库复制手艺 完成数据同步更新

这能找出所有错误的99.99%。它不能找出的是仅仅涉及数据文件的损坏(这很不常见)。如果你想要检查一张表,你通常应该没有选项地运行myisamchk或用-s或--silent选项的任何一个。数据|数据库|数据同步
使用数据库复制手艺完成数据同步更新
复制的观点
复制是将一组数据从一个数据源拷贝到多个数据源的手艺,是将一份数据公布到多个存储站点上的无效体例。利用复制手艺,用户能够将一份数据公布到多台服务器上,从而使分歧的服务器用户都能够在权限的允许的局限内共享这份数据。复制手艺能够确保散布在分歧地址的数据主动同步更新,从而包管数据的分歧性。
SQL复制的基础元素包含
出书服务器、定阅服务器、分发服务器、出书物、文章
SQL复制的事情道理
SQLSERVER次要接纳出书物、定阅的体例来处置复制。源数据地点的服务器是出书服务器,卖力宣布数据。出书服务器把要宣布的数据的一切改动情形的拷贝复制到分发服务器,分发服务器包括有一个分发数据库,可吸收数据的一切改动,并保留这些改动,再把这些改动分发给定阅服务器
SQLSERVER复制手艺范例
SQLSERVER供应了三种复制手艺,分离是:
1、快照复制(呆会我们就利用这个)
2、事件复制
3、兼并复制
只需把下面这些观点弄分明了那末对复制也就有了必定的了解。接上去我们就一步一步来完成复制的步骤。
第一先来设置出书服务器
(1)选中指定[服务器]节点
(2)从[工具]下拉菜单的[复制]子菜单当选择[公布、定阅服务器和分发]命令
(3)体系弹出一个对话框点[下一步]然后看着提醒一向操纵到完成。
(4)当完成了出书服务器的设置今后体系会为该服务器的树形布局中增加一个复制监督器。同时也天生一个分发数据库(distribution)
第二创立出书物
(1)选中指定的服务器
(2)从[工具]菜单的[复制]子菜单当选择[创立和办理公布]命令。此时体系会弹出一个对话框
(3)选择要创立出书物的数据库,然后单击[创立公布]
(4)在[创立公布导游]的提醒对话框中单击[下一步]体系就会弹出一个对话框。对话框上的内容是复制的三个范例。我们如今选第一个也就是默许的快照公布(其他两个人人能够往看看匡助)
(5)单击[下一步]体系请求指定能够定阅该公布的数据库服务器范例,SQLSERVER同意在分歧的数据库如ORACLE或ACCESS之间举行数据复制。可是在这里我们选择运转"SQLSERVER2000"的数据库服务器
(6)单击[下一步]体系就弹出一个界说文章的对话框也就是选择要出书的表
(7)然后[下一步]直到操纵完成。当完成出书物的创立后创立出书物的数据库也就酿成了一个共享数据库。
第三计划定阅
(1)选中指定的定阅服务器
(2)从[工具]下拉菜单当选择[复制]子菜单的[哀求定阅]
(3)依照单击[下一步]操纵直到体系会提醒反省SQLSERVER代办署理服务的运转形态,实行复制操纵的条件前提是SQLSERVER代办署理服务必需已启动。
(4)单击[完成]。完成定阅操纵。
完成下面的步骤实在复制也就是乐成了。可是怎样来晓得复制是不是乐成了呢?这里能够经由过程这类办法来疾速看是不是乐成。睁开出书服务器上面的复制——公布内容——右键公布内容——属性——击活——形态然后点当即运转代办署理程序接着点代办署理程序属性击活调剂把调剂设置为每天产生,每分钟,在0:00:00和23:59:59之间。接上去就是判别复制是不是乐成了翻开C:ProgramFilesMicrosoftSQLServerMSSQLREPLDATAuncXIAOWANGZI_database_database上面看是否是有一些以工夫做为文件名的文件夹差未几一分中就发生一个。如果你还不信的话就翻开你的数据库看在定阅的服务器的指定定阅数据库下看是否是看到了你方才所公布的表—

一个手工同步的计划
--准时同步服务器上的数据
--例子:
--测试情况,SQLServer2000,远程服务器名:xz,用户名为:sa,无暗码,测试数据库:test
--服务器上的表(查询剖析器毗连到服务器上创立)
createtable(idintprimarykey,numbervarchar(4),namevarchar(10))
go
--以下在局域网(本机操纵)
--本机的表,state申明:null暗示新增纪录,1暗示修正过的纪录,0暗示无变更的纪录
ifexists(select*fromdbo.sysobjectswhereid=object_id(N)andOBJECTPROPERTY(id,NIsUserTable)=1)
droptable
GO
createtable(idintidentity(1,1),numbervarchar(4),namevarchar(10),statebit)
go
--创立触发器,保护state字段的值
createtriggert_stateon
afterupdate
as
updatesetstate=1
fromajoininsertedbona.id=b.id
wherea.stateisnotnull
go
--为了便利同步处置,创立链接服务器到要同步的服务器
--这里的远程服务器名为:xz,用户名为:sa,无暗码
ifexists(select1frommaster..sysserverswheresrvname=srv_lnk)
execsp_dropserversrv_lnk,droplogins
go
execsp_addlinkedserversrv_lnk,,SQLOLEDB,xz
execsp_addlinkedsrvloginsrv_lnk,false,null,sa
go
--创立同步处置的存储历程
ifexists(select*fromdbo.sysobjectswhereid=object_id(N.)andOBJECTPROPERTY(id,NIsProcedure)=1)
dropprocedure.
GO
createprocp_synchro
as
--setXACT_ABORTon
--启动远程服务器的MSDTC服务
--execmaster..xp_cmdshellisql/S"xz"/U"sa"/P""/q"execmaster..xp_cmdshellnetstartmsdtc,no_output",no_output
--启动本机的MSDTC服务
--execmaster..xp_cmdshellnetstartmsdtc,no_output
--举行散布事件处置,假如表用标识列做主键,用上面的办法
--BEGINDISTRIBUTEDTRANSACTION
--同步删除的数据
deletefromsrv_lnk.test.dbo.
whereidnotin(selectidfrom)
--同步新增的数据
insertintosrv_lnk.test.dbo.
selectid,number,namefromwherestateisnull
--同步修正的数据
updatesrv_lnk.test.dbo.set
number=b.number,name=b.name
fromsrv_lnk.test.dbo.a
joinbona.id=b.id
whereb.state=1
--同步后更新本机的标记
updatesetstate=0whereisnull(state,1)=1
--COMMITTRAN
go
--创立功课,准时实行数据同步的存储历程
ifexists(SELECT1frommsdb..sysjobswherename=数据处置)
EXECUTEmsdb.dbo.sp_delete_job@job_name=数据处置
execmsdb..sp_add_job@job_name=数据处置
--创立功课步骤
declare@sqlvarchar(800),@dbnamevarchar(250)
select@sql=execp_synchro--数据处置的命令
,@dbname=db_name()--实行数据处置的数据库名
execmsdb..sp_add_jobstep@job_name=数据处置,
@step_name=数据同步,
@subsystem=TSQL,
@database_name=@dbname,
@command=@sql,
@retry_attempts=5,--重试次数
@retry_interval=5--重试距离
--创立调剂
EXECmsdb..sp_add_jobschedule@job_name=数据处置,
@name=工夫布置,
@freq_type=4,--天天
@freq_interval=1,--天天实行一次
@active_start_time=00000--0点实行
go
根据Ambrose所说,Sakila来自一种叫SiSwati的斯威士兰方言,也是在Ambrose的家乡乌干达附近的坦桑尼亚的Arusha的一个小镇的名字。

分手快乐 发表于 2015-1-19 19:10:17

SQLServer的异构移植功能个人感觉最好了。(如果对比过SQLServer的链接服务器和Oracle的透明网关的朋友会发现SQLServer的sp_addlinkedserver(openquery)异构数据库系列比Oracle真是强太多了。)

小魔女 发表于 2015-2-5 20:21:24

语句级快照和事务级快照终于为SQLServer的并发性能带来了突破。个人感觉语句级快照大家应该应用。事务级快照,如果是高并发系统还要慎用。如果一个用户总是被提示修改不成功要求重试时,会杀人的!

活着的死人 发表于 2015-2-13 12:51:29

我是新手,正在学习数据库和操作系统,深感理论的泛广,唯有一步一步来,但是又感觉时间不够,收集了很多资料却总是没能认真的看完,希望有一个讨论板块,大家共同解决,共同分享,共同努力

柔情似水 发表于 2015-3-3 21:22:11

SQL语言是学习所有数据库产品的基础,无论你是做数据库管理还是做数据库开发都是这样。不过具体学习的侧重点要看你将来做哪一块,如果是做数据库管理(DBA),侧重点应该放在SQLServer的系统管理上.

爱飞 发表于 2015-3-11 13:53:16

varchar(max)\\\\nvarchar(max)类型的引入大大的提高了编程的效率,可以使用字符串函数对CLOB类型进行操作,这是一个亮点。

再现理想 发表于 2015-3-18 15:57:10

同样会为索引视图等应用带来麻烦。看看行级和事务级的快照数据放在tempdb中,就能感觉到目前架构的尴尬。

愤怒的大鸟 发表于 2015-3-26 02:55:01

对递归类的树遍历很有帮助。个人感觉这个真是太棒了!阅读清晰,非常有时代感。
页: [1]
查看完整版本: MSSQL教程之使用数据库复制手艺 完成数据同步更新