收藏 分享(赏)

SQL Server 2005数据库实践教程—4.第四章 .数据库转换与复制技术.ppt

上传人:weiwoduzun 文档编号:3534387 上传时间:2018-11-12 格式:PPT 页数:96 大小:3.21MB
下载 相关 举报
SQL Server 2005数据库实践教程—4.第四章 .数据库转换与复制技术.ppt_第1页
第1页 / 共96页
SQL Server 2005数据库实践教程—4.第四章 .数据库转换与复制技术.ppt_第2页
第2页 / 共96页
SQL Server 2005数据库实践教程—4.第四章 .数据库转换与复制技术.ppt_第3页
第3页 / 共96页
SQL Server 2005数据库实践教程—4.第四章 .数据库转换与复制技术.ppt_第4页
第4页 / 共96页
SQL Server 2005数据库实践教程—4.第四章 .数据库转换与复制技术.ppt_第5页
第5页 / 共96页
点击查看更多>>
资源描述

1、1,SQL Server 2005数据库实践教程 管理与维护篇,主讲教师:钱 哨,交通部管理干部学院计算机系 钱哨教案,第四章. 数据库转换与复制技术,2,本章教学目标,数据的导入与导出 SQL Server Integration Services介绍及数据转换操作 SQL Server2005复制技术,3,4-1 数据的导入与导出,掌握数据库表中数据的导出技术,包括:将SQL Server数据导出为文本文件,导出到本机内其他数据库中,导出到Access数据库中; 掌握将异构数据导入到SQL Server数据库,包括:将文本文件数据,Access数据导入到SQL Server数据库。,4,4

2、-1 数据的导入与导出,4-1-1 数据库表数据导出,实验1:将SQL Server数据导出为文本文件实验,第一步:用鼠标右键单击“对象资源管理器”中的“school”数据库对象。在弹出的快捷菜单中选择“任务”“导出数据”选项,如图所示。,5,4-1 数据的导入与导出,4-1-1 数据库表数据导出,实验1:将SQL Server数据导出为文本文件实验,第二步:在“SQL Server导入和导出”窗口中,选择导出数据的数据源。在本例中,选择数据源为SQL Native Client(表示本机数据),选择导出数据的数据库为school,如图所示,然后按“下一步”按钮。,6,4-1 数据的导入与导出

3、,4-1-1 数据库表数据导出,实验1:将SQL Server数据导出为文本文件实验,第三步:在“导入和导出向导”窗口中,选择导出数据的目标,即导出数据复制到何处。如果选择“SQL Native Client”选项,则将本机的SQL Server数据库数据导出到其他计算机的SQL Server服务器中;如果选择“Microsoft Excel”选项,则将SQL Server数据库数据导出到Excel文件中;如果选择“Microsoft Access”选项,则将SQL Server数据库数据导出到Access数据库中等等。在本例中,选择目标为“平面文件目标”,并指定该文件的路径名为c:backs

4、chool.txt,如图所示,然后按“下一步”按钮 。,7,4-1 数据的导入与导出,4-1-1 数据库表数据导出,实验1:将SQL Server数据导出为文本文件实验,第四步:在“导入和导出向导”窗口中,选择从表中复制数据或者从查询中复制数据。在本例中,选择“复制一个或多个表或视图的数据”单选项,如图所示,然后按“下一步”按钮,8,4-1 数据的导入与导出,4-1-1 数据库表数据导出,实验1:将SQL Server数据导出为文本文件实验,第五步:在“导入和导出向导”窗口中,选择从复制数据的源表或源视图。在本例中,在下拉列表中选择表student,如图所示,然后按“下一步”按钮。,9,4-1

5、 数据的导入与导出,4-1-1 数据库表数据导出,实验1:将SQL Server数据导出为文本文件实验,第六步:在“导入和导出向导”窗口中,选择“立即执行”复选框,然后按“下一步”按钮。完成导出数据的向导设置后,在“导入和导出向导”窗口中,单击“完成”按钮,如图所示 。,10,4-1 数据的导入与导出,4-1-1 数据库表数据导出,实验1:将SQL Server数据导出为文本文件实验,第七步:导出数据操作完成后,弹出执行成功的对话框提示成功导出了9行数据,如图所示。此时,在操作系统下生成了一个新的文本文件。打开导出到文件,可以看到该文件中记录了导出的数据。,11,4-1 数据的导入与导出,4-

6、1-1 数据库表数据导出,实验2:将SQL Server数据导出到本机内其他数据库实验,第一步:在案例1的选择目标中,选择目标也是SQL Native Client,数据库选择master,如图所示。在此界面中,服务器名可以改为局域网络环境下其他的SQL Server数据库服务器,这样可以直接实现在网络环境下的数据导出实验,12,4-1 数据的导入与导出,4-1-1 数据库表数据导出,实验2:将SQL Server数据导出到本机内其他数据库实验,第二步:选择源表为student表,点击下一步,直至完成后就可以将student表导出到master数据库之中,13,4-1 数据的导入与导出,4-1

7、-1 数据库表数据导出,实验3:将SQL Server数据导出到Access数据库实验,第一步:在本机内新建一个access数据库文件,命名为school.mdb,即该文件内数据信息为空。在案例1的选择目标中,数据源选择目标是SQL Native Client,确定数据源指定的本机SQL Server数据库为school数据库。在下一步选择目标界面中,确定目标为Microsoft Access数据库,如图所示,14,4-1 数据的导入与导出,4-1-1 数据库表数据导出,实验3:将SQL Server数据导出到Access数据库实验,第二步:单击浏览按钮,选择具体磁盘中的Access数据库文件

8、,此处我们选择school.mdb文件作为导出数据表,15,4-1 数据的导入与导出,4-1-1 数据库表数据导出,实验3:将SQL Server数据导出到Access数据库实验,第三步:选择将导出的具体数据表,并勾选具体的表信息。连续点击下一步就可以将具体数据库之中的数据表导出到Access数据库之中,16,4-1 数据的导入与导出,4-1-1 数据库表数据导出,实验3:将SQL Server数据导出到Access数据库实验,第三步:选择将导出的具体数据表,并勾选具体的表信息。连续点击下一步就可以将具体数据库之中的数据表导出到Access数据库之中,17,4-1 数据的导入与导出,4-1-1

9、 数据库表数据导出,实验3:将SQL Server数据导出到Access数据库实验,第三步:在转换过程中,我们也可以很明显看到的逻辑结构差异是:主码标志丢失,数据类型改变(如int类型改为长整数类型,varchr类型改变为备注类型等)等等,如图所示。因此,数据的导出仅仅是将具体的数据内容进行了导出,而关系型数据库的全局逻辑结构并不会随之被导出,这是因数据库管理软件的差异而产生的,18,4-1 数据的导入与导出,4-1-2 将异构数据导入到SQL Server数据库,实验1:将文本文件数据导入到SQL Server数据库实验,第一步:打开资源管理平台,用鼠标右键单击“对象资源管理器”中的scho

10、ol数据库对象。在弹出的快捷菜单中选择“任务”-“导入数据”选项,如图所示,19,4-1 数据的导入与导出,4-1-2 将异构数据导入到SQL Server数据库,实验1:将文本文件数据导入到SQL Server数据库实验,第一步:在“SQL Server 导入和导出向导”窗口中,选择导入数据的数据源。在本例中,选择数据源为平面文件源,指定导入数据的文本文件名,如图 所示,然后按“下一步”按钮,20,4-1 数据的导入与导出,4-1-2 将异构数据导入到SQL Server数据库,实验1:将文本文件数据导入到SQL Server数据库实验,第二步:在“SQL Server 导入和导出向导”窗口

11、中,选择导入数据的数据源。在本例中,选择数据源为平面文件源,指定导入数据的文本文件名,如图 所示,然后按“下一步”按钮,21,4-1 数据的导入与导出,4-1-2 将异构数据导入到SQL Server数据库,实验1:将文本文件数据导入到SQL Server数据库实验,第三步:此时将进入选择源表和源视图界面,如图所示。此时,如果希望更新即将导入的数据类型,可以单击“编辑映射”按钮,对具体的文本文件中的列数据类型与目标数据的映射关系进行最后的编辑工作,22,4-2 SQL Server Integration Services介绍,4-2 SQL Server Integration Servic

12、es介绍,了解SSIS的基本概念和体系结构;掌握使用SSIS进行数据转换,包括:通过操作系统的ODBC将Access数据库中的数据导入到SQL Server,使用迭代方法将文本数据导入到SQL Server 2005。,23,4-2 SQL Server Integration Services介绍,SQL Server Integration Services(SSIS)也被称为是SQL Server集成服务,该集成服务是SQL Server 2005中面向高性能数据集成的功能组成,它有一个配套的数据流机制和控制流机制,并且可以为数据分析服务提供必要的ETL支持。,4-2-1 SSIS的体系

13、结构,1. 任务流和数据流引擎数据流也称为流水线,主要解决数据转换的问题。数据流由一组预定义的转换操作组成。数据流的起点通常是数据源(源表);数据流的终点通常是数据的目的地(目标表)。可以将数据流的执行认为是一个流水线的过程,在该过程中,每一行数据都是装配线中需要处理的零件,而每一个转换都是装配线中的处理单元。任务流引擎为数据流引擎提供运行时资源和操作支持。任务流和数据流的这一组合使得 SSIS 可以有效应用于传统ETL(Extraction-Transformation-Loading,数据抽取、转换和加载)或数据仓库(DW)场景中,也可有效应用于很多其他扩展场景中,如数据中心操作,4-2

14、SQL Server Integration Services介绍,24,4-2-1 SSIS的体系结构,2. 管线结构SSIS 的核心是数据转换管线。此管线具有面向缓冲区的结构,一旦数据行集加载到内存中后,数据行集操作将非常快。采用此方法将在单个操作中执行ETL过程的全部数据转换步骤,而不会对数据进行暂存,不过具体的转换或操作要求或者硬件可能对此形成障碍。不过,为了最大化性能,该结构将避免进行暂存。,3. 流程转换SSIS把业务流程和数据转换流程分成两个部分来处理,这样对处理复杂问题会有很大帮助。在一个SSIS工程下,可以有若干个包(Package),每个包为一个独立的处理事件(如图所示),

15、包(package)是SSIS项目中基本的部署和执行单元,也是一个有组织的集合,其中包括连接、控制流元素、数据流元素、事件处理程序、变量和配置等。,4-2 SQL Server Integration Services介绍,25,4-2-1 SSIS的体系结构,4-2 SQL Server Integration Services介绍,26,4-2-2 使用SSIS进行数据转换,使用SSIS进行数据转换是SSIS比较简单的操作,可以通过启动 Business Intelligence Development Studio,然后创建一个Integration Services项目来调用SSIS设

16、计器(如图所示),4-2 SQL Server Integration Services介绍,27,4-2-2 使用SSIS进行数据转换,在展开的设计界面左边有一个工具箱窗口,通过鼠标点击并查看该工具箱,该工具箱窗口包含预定义的控制流项和维护计划中的任务,4-2 SQL Server Integration Services介绍,28,4-2-2 使用SSIS进行数据转换,中间的视图窗格包含4个视图:控制流、数据流、事件处理程序和包资源管理器,如图所示。控制流视图提供了一个设计环境,在这个设计环境中可以使用工具箱中与控制流相关的项来构建控制流。数据流视图也提供了一个设计环境,在这个设计环境中可

17、以使用工具箱中与数据流相关的项来构建数据流。在事件处理程序视图中,可以定义由特定的执行事件触发的后续响应操作。包资源管理器视图提供了流的树型视图,4-2 SQL Server Integration Services介绍,29,4-2-2 使用SSIS进行数据转换,中间的视图窗格包含4个视图:控制流、数据流、事件处理程序和包资源管理器,如图所示。控制流视图提供了一个设计环境,在这个设计环境中可以使用工具箱中与控制流相关的项来构建控制流。数据流视图也提供了一个设计环境,在这个设计环境中可以使用工具箱中与数据流相关的项来构建数据流。在事件处理程序视图中,可以定义由特定的执行事件触发的后续响应操作。

18、包资源管理器视图提供了流的树型视图,4-2 SQL Server Integration Services介绍,30,4-2-2 使用SSIS进行数据转换,实验1:通过操作系统的ODBC将Access数据库中的数据导入到SQL Server,第一步:配置操作系统的ODBC接口,使得该接口指向某种类型的数据库系统,这里假设指向ACCESS数据库。设置流程为:开始-设置-控制面板-管理工具-数据源 (ODBC),在展开的ODBC界面中,选择系统DSN,点击添加。,4-2 SQL Server Integration Services介绍,31,4-2-2 使用SSIS进行数据转换,实验1:通过操作

19、系统的ODBC将Access数据库中的数据导入到SQL Server,第二步:在展开的配置界面之中,我们可以看见各种微软公司为各个数据库厂商提供的数据库接口,这里我们选择Microsoft Access Driver,为Access数据库配置接口。分别填写数据源逻辑名和说明后,点击选择按钮,将本机磁盘中的school.mdb文件选择进来,最后点击确定则该接口就与磁盘中的school.mdb文件连接起来,4-2 SQL Server Integration Services介绍,32,4-2-2 使用SSIS进行数据转换,实验1:通过操作系统的ODBC将Access数据库中的数据导入到SQL S

20、erver,第三步:回到SSIS管理平台,在右侧“解决方案资源管理器”中用鼠标右键单击数据源,并新建一个数据源,4-2 SQL Server Integration Services介绍,33,4-2-2 使用SSIS进行数据转换,实验1:通过操作系统的ODBC将Access数据库中的数据导入到SQL Server,第四步:在展开的数据源向导界面之中点击下一步,并选择新建一个新的数据源,在弹出的连接管理器界面之中,于提供程序下拉列表框中选择.NET提供程序中的“odbc data provider”。而后在指定的数据源中,选择系统数据源名称是“school”。最后,点击该界面中的“测试连接”按

21、钮,等待弹出“测试成功”字样后,点击确定完成新建数据源的工作,如图所示。最后,回到数据源界面后,点击下一步,完成当前数据源向导的配置工作,4-2 SQL Server Integration Services介绍,34,4-2-2 使用SSIS进行数据转换,实验1:通过操作系统的ODBC将Access数据库中的数据导入到SQL Server,第六步:在SQL Server 2005中新建目标数据库school1,并在该数据库中建立基本表student,该表的基本结构,4-2 SQL Server Integration Services介绍,35,4-2-2 使用SSIS进行数据转换,实验1:

22、通过操作系统的ODBC将Access数据库中的数据导入到SQL Server,第七步:回到SSIS管理平台,在右侧“解决方案资源管理器”中用鼠标右键单击数据源,再新建一个数据源指向SQL Server 2005中新建的数据库school1。在数据源向导中的配置连接管理器界面中,配置新的SQL Server 2005数据源,配置的基本参数如图所示,最后点击测试连接,显示“测试成功连接”为止。请注意,目前为止school数据源代表着ODBC数据源,而school1代表着SQL Server 2005数据源,4-2 SQL Server Integration Services介绍,36,4-2-2

23、 使用SSIS进行数据转换,实验1:通过操作系统的ODBC将Access数据库中的数据导入到SQL Server,第八步:在SSIS管理平台的下部有连接管理器部分,用鼠标右键单击该部分,在弹出的快捷菜单中选择“从数据源新建连接”,并在弹出的选择数据源界面中选择数据源”school”;如法炮制在建立数据源”school1”。此时会在连接管理器部分出现两个数据源”school” 和”school1”,4-2 SQL Server Integration Services介绍,37,4-2-2 使用SSIS进行数据转换,实验1:通过操作系统的ODBC将Access数据库中的数据导入到SQL Serv

24、er,第九步:从SSIS管理平台左侧的工具箱中的“数据流源”处拖拽“DataReader源”到数据流界面中,该控件意味着数据流转换的起始源头,再从工具箱中的“数据流目标”处拖拽“OLE DB目标”到数据流界面中,该控件意味着数据流转换的目标终点,4-2 SQL Server Integration Services介绍,38,4-2-2 使用SSIS进行数据转换,实验1:通过操作系统的ODBC将Access数据库中的数据导入到SQL Server,第十步:在SSIS管理平台的数据流界面中鼠标右击“DataReader源”控件对象,并在弹出的快捷菜单中选择编辑。在弹出配置界面中选择连接管理器为s

25、chool,4-2 SQL Server Integration Services介绍,39,4-2-2 使用SSIS进行数据转换,实验1:通过操作系统的ODBC将Access数据库中的数据导入到SQL Server,第十步:此时“DataReader源”控件对象出现惊叹号,表现为该组件的元数据不一致问题。双击该控件将弹出“检查sqlcommand属性”的提示,而该属性为SQL脚本命令。,4-2 SQL Server Integration Services介绍,40,4-2-2 使用SSIS进行数据转换,实验1:通过操作系统的ODBC将Access数据库中的数据导入到SQL Server,第

26、十步:编辑该控件的sqlcommand属性,键入查询语句命令”select * from student”,则元数据不一致问题解决,,4-2 SQL Server Integration Services介绍,41,4-2-2 使用SSIS进行数据转换,实验1:通过操作系统的ODBC将Access数据库中的数据导入到SQL Server,第十步:配置结束后,将“DataReader源”控件对象中的绿色线段拖至“OLE DB目标”对象,建立起两个控件彼此之间的关联,4-2 SQL Server Integration Services介绍,42,4-2-2 使用SSIS进行数据转换,实验1:通过

27、操作系统的ODBC将Access数据库中的数据导入到SQL Server,第十二步:但是此时目标数据库依然有错误提示,如图所示。该错误主要是由于源数据和目标数据表的数据格式不一致造成的,解决的办法是修改school1数据库的student表的数据类型,从而与Access数据库相对应一致。,4-2 SQL Server Integration Services介绍,43,4-2-2 使用SSIS进行数据转换,实验1:通过操作系统的ODBC将Access数据库中的数据导入到SQL Server,第十二步:此时点击SSIS界面上的运行按钮,执行后数据利用ODBC接口正确从Access数据库导入到SQ

28、L Server 2005数据库之中。,4-2 SQL Server Integration Services介绍,44,4-2-2 使用SSIS进行数据转换,实验2:使用迭代方法将文本数据导入到SQL Server 2005,第一步:准备工作 (1)在磁盘上新建一个文件夹Txt,并建立两个文本文件:userinfo1.txt和userinfo2.txt。假设在两个文本文件中分别写入如下信息: userinfo1.txt:1|张三|我是张三|男,2|李四|我是李四|女,4|张三|我是张三|男,5|李四|我是李四|女 userinfo2.txt:6|张三1|我是张三1|男,7|李四1|我是李四1

29、|女,8|张三2|我是张三2|男,9|李四2|我是李四2|女(2)在SQL Server 2005下新建数据库ssis,并在数据库ssis下建立数据表userinfo,基本结构如图所示。,4-2 SQL Server Integration Services介绍,45,4-2-2 使用SSIS进行数据转换,实验2:使用迭代方法将文本数据导入到SQL Server 2005,本案例实验目标就是循环地连接某文件夹下的每个文件,不需要为每个文件都建立连接管理器。在这个实例中,我们将某文件夹下的userinfo1.txt和userinfo2.txt的内容都写入数据表userinfo中。,第二步:设置F

30、oreach循环编辑器 (1)在SSIS管理平台下新建一个项目,在控制流界面中从左侧工具箱中拖拽Foreach循环容器到界面中,然后再从工具箱中拖拽数据流任务到Foreach循环容器中,如图所示,4-2 SQL Server Integration Services介绍,46,4-2-2 使用SSIS进行数据转换,实验2:使用迭代方法将文本数据导入到SQL Server 2005,(2)鼠标右击Foreach循环容器,在展开的Foreach循环编辑器中的“集合”进行枚举器的配置,设置文件夹为存放txt文档的文件夹:D:txt,指定文件类型为*.txt,表示全部的txt文件,如图所示。,4-2

31、SQL Server Integration Services介绍,47,4-2-2 使用SSIS进行数据转换,实验2:使用迭代方法将文本数据导入到SQL Server 2005,(3)选择Foreach循环编辑器中的变量映射,设置枚举器映射为用户定义的变量,名称为VarFileName,如图所示。,4-2 SQL Server Integration Services介绍,48,4-2-2 使用SSIS进行数据转换,实验2:使用迭代方法将文本数据导入到SQL Server 2005,3. 第三步:配置平面文件和SQL Server连接管理器 (1)设置平面文件连接管理器。在连接管理器区域鼠标

32、右键选择新建平面文件连接,在弹出的平面文件编辑器中的常规选项中,将D:txt中的某个txt文件导入。在列选项中,将行分隔符设置为“逗号 ,”,将列分隔符设置为“竖线 |”。在高级选项中,修改各个属性的名称,如图所示。点击确定后平面文件连接管理器的配置工作完毕,4-2 SQL Server Integration Services介绍,49,4-2-2 使用SSIS进行数据转换,实验2:使用迭代方法将文本数据导入到SQL Server 2005,(2)设置SQL Server连接管理器。在连接管理器区域鼠标右键选择新建OLE DB连接,在弹出的连接管理器中,设置服务器为(local),选择数据库

33、为ssis,测试成功后点击确定建立连接,如图所示,4-2 SQL Server Integration Services介绍,50,4-2-2 使用SSIS进行数据转换,实验2:使用迭代方法将文本数据导入到SQL Server 2005,4. 第四步:设置数据流任务 (1)进入SSIS管理中的数据流界面,并从工具箱中拖拽一个平面文件源到其中,鼠标右键单击该文件源控件,选择编辑。在打开的平面文件源编辑器中,选择平面文件管理器为上步建立的userinfo对象。再从工具箱的数据流目标中拖拽一个OLE DB对象到数据流界面中,并建立与平面文件数据源对象的连接关系,4-2 SQL Server Inte

34、gration Services介绍,51,4-2-2 使用SSIS进行数据转换,实验2:使用迭代方法将文本数据导入到SQL Server 2005,(2)编辑OLE DB对象。在打开的OLE DB目标编辑器中,选择OLE DB连接管理器为(local).ssis,表或视图的名称为userinfo。然后选择映射,自动建立起与平面文件之间的关联,如图所示。,4-2 SQL Server Integration Services介绍,52,4-2-2 使用SSIS进行数据转换,实验2:使用迭代方法将文本数据导入到SQL Server 2005,第五步:执行任务 点击工具栏中的运行图标,则最终将数据

35、由平面文件夹下面将全部的TXT文件数据内容复制到SQL Server中,颜色显示为绿色,4-2 SQL Server Integration Services介绍,53,4-3 SQL Server2005复制技术,了解复制的概念和基本类型;了解“复制”中的服务器角色有哪些;掌握“复制”的服务器配置,包括:如何创建发布服务器,分发服务器和订阅服务器;熟练配置事务复制和快照复制。,54,4-3 SQL Server2005复制技术,4-3-1 “复制”简介,复制是将数据或数据库对象从一个数据库复制和分发到另外一个数据库,并进行数据同步,从而使源数据库和目标数据库保持一致。使用复制,可以在局域网和

36、广域网、拨号连接、无线连接和Internet上将数据分发到不同位置以及分发给远程或移动用户。 一组SQL Server 2005复制由发布服务器、分发服务器、订阅服服务器(如图所示)组成,它们之间的关系类似于书报行业的报社或出版社、邮局或书店、读者之间的关系,55,4-3 SQL Server2005复制技术,4-3-1 “复制”简介,在很多情况下,一个数据库服务器实例充当发布服务器和分发服务器两个角色,这称为“本地分发服务器”。订阅服务器是接收复制数据的数据库实例。一个订阅服务器可以从多个发布服务器和发布接收数据,56,4-3 SQL Server2005复制技术,4-3-2 “复制”中的服

37、务器角色,1. 发布服务器的角色 发布服务器具有数据的原始副本,并使其可供订阅服务器使用。发布服务器上的数据被发送给分发服务器,然后再由分发服务器将数据传递给订阅服务器。 2. 分发服务器的角色 分发服务器用于存储状态信息副本和元数据副本,有时它还用于存储在发布服务器和订阅服务器之间传递的数据。发布服务器也可以作为分发服务器(称为本地分发服务器),但是在复制量很大时候,通常会单独创建一个分发服务器(称为远程分发服务器)。多个发布服务器可以使用一个分发服务器,而且每个发布服务器都在该分发服务器上具有独立的数据库。,57,4-3 SQL Server2005复制技术,4-3-2 “复制”中的服务器

38、角色,3. 订阅服务器的角色订阅服务器保存数据的复制副本,可以对订阅服务器进行如下的设置:组织其对数据库进行修改允许其在发布服务器处进行修改允许其进行本地修改,并随后合并在一起,58,4-3 SQL Server2005复制技术,4-3-3 “复制”的类型,SQL SEVER提供了三大类复制类型:快照复制、事务复制、合并复制。可以在实际应用中使用相应的复制类型,每一种复制类型都在不同程序上实现数据的一致性,1. 快照复制 快照复制是最为简单的一种复制类型,能够在出版者和订阅者之间保证数据的一致性。快照复制通常使用在以下场合:在一定时间内出现大量的更改的操作,但数据总量不大,变化周期较长。,59

39、,4-3 SQL Server2005复制技术,4-3-3 “复制”的类型,2. 事务复制 事务复制使用事务日志来生成将复制到订阅服务器的事务,因为它只复制事务也就是变化,所以滞后也比快照复制低得多,并且事务复制中的订阅服务器将不断地在发布服务器处得到最新的数据变化,从而在同步性的执行效率方面比快照复制要快得多,特别是在大量数据进行远程复制的情况下尤为明显。事务复制与快照复制之间的差异可以通过图反映出来,60,4-3 SQL Server2005复制技术,4-3-3 “复制”的类型,2. 事务复制 事务复制有三个组件:快照代理,它生成架构,数据以及跟踪复制过程所需的数据;分发代理:它分发快照和

40、随后的命令;日志读取器代理:它读取发布数据的事务日志。,61,4-3 SQL Server2005复制技术,4-3-3 “复制”的类型,3. 合并复制 在要复制的每个表上实现触发器,并使用包含GUID列唯一标识要复制的表中的每一行。对其中的任何一个表进行修改时,都会将更改的记录到该数据表中,在合并代理运行时,它收集数据表中的GUID,这些GUID指出了在发布服务器和订阅服务器处修改过的行。对于只在发布服务器或是订阅端修改的数据则直接进行相应操作,如INSERT,UPDATE,DELETE,如果双方都有GUID则按照用户指定的方式解决冲突,默认发布服务器伏先,62,4-3 SQL Server2

41、005复制技术,4-3-4 “复制”的服务器配置,无论是快照复制,事务性复制还是合并复制,创建复制都要经过以下几个步骤:第一步:创建发布服务器。选择要发布的服务器。如果有条件的,也可以分发服务器,在这里我们就将发布服务器和分发服务器设置在同一台计算机上。第二步:不论是发布服务器还是订阅服务器必须开启代理服务。第三步:创建一个发布。即将需要的数据库及对象发布出来。第四步:选择一个适合自己的发布类型。第五步:设置复制代理及安全,即指定可以运行代理的用户帐号。,63,4-3 SQL Server2005复制技术,4-3-4 “复制”的服务器配置,实验1:快照复制实验,1. 第一步:在本机建立不同的实

42、例 本次实验在同一台机器的二个实例间进行,实例名分别是本机的Administrator用户登录(假设为SERVER01)和本机的SQLExpress实例登录(假设为SERVER02)。将SERVER01配置发布服务器和分发服务器(也就是前面提到的“本地分发服务器”),SERVER02配置为订阅服务器。在本例中将SERVER01中school库的student表作为发布的数据,在发布前请确保student表有主键、SQL SERVER 代理自动启动、发布数据库是日志是完整模式。另外,SERVER02中也有school数据库,其中的表信息及数据与SERVER01中的school数据库完全一致,从而

43、保证复制前的同步,使用发布的源和目标数据一致。,64,4-3 SQL Server2005复制技术,4-3-4 “复制”的服务器配置,实验1:快照复制实验,2. 第二步:在SERVER01上设置发布和分发 (1)展开在SERVER01的复制节点,在本地发布右键选择新建订阅。,65,4-3 SQL Server2005复制技术,4-3-4 “复制”的服务器配置,实验1:快照复制实验,(2)在新建发布向导中首先要求选择分发服务器,本例选择本机作为分发服务器, 选择默认值 。,66,4-3 SQL Server2005复制技术,4-3-4 “复制”的服务器配置,实验1:快照复制实验,(3)向导第三步

44、要求选择快照的路径,一般情况下选择默认路径。向导第四步选择发布的数据库,选择school,67,4-3 SQL Server2005复制技术,4-3-4 “复制”的服务器配置,实验1:快照复制实验,(4)接着选择发布的类型,这里选择快照复制,68,4-3 SQL Server2005复制技术,4-3-4 “复制”的服务器配置,实验1:快照复制实验,(5)选择发布的内容(student),这里不仅可以发表,还可以发布其他的数据库对象,比如函数。在选择某一个表之后还可以选择发布某一列或几列。在这个步骤下一个界面中可以选择要发布的行,这里我们默认行发布,69,4-3 SQL Server2005复制

45、技术,4-3-4 “复制”的服务器配置,实验1:快照复制实验,(6)配置快照代理服务,此处需要将“立即执行快照”和“计划时间运行”全部勾选上,并点击确定执行快照复制。,70,4-3 SQL Server2005复制技术,4-3-4 “复制”的服务器配置,实验1:快照复制实验,(7)下面为每个复制代理选择登录名,点击向导配置安全代理服务。设置发布的内容之后设置运行SQL代理的账号,设置如下,71,4-3 SQL Server2005复制技术,4-3-4 “复制”的服务器配置,实验1:快照复制实验,(8)设置上一步之后,给复制起个名字school_fb。到此为止,发布和分发已配置成功,72,4-3

46、 SQL Server2005复制技术,4-3-4 “复制”的服务器配置,实验1:快照复制实验,3. 第三步:在SERVER02上设置订阅服务器 (1)下面就可以进行订阅了,订阅可以在发布服务器上进行,也可以在订阅服务器上进行。本次我们在订阅服务器实例SERVER2上操作订阅。展开SERVER2实例的复制项,在本地订阅上右击属性,选择新建订阅。在新建订阅的界面,首先新建订阅向导,在发布服务器中选择登录的服务器为SERVER1,73,4-3 SQL Server2005复制技术,4-3-4 “复制”的服务器配置,实验1:快照复制实验,(2)选择SERVER1实例中发布数据库school_fb后,

47、进入新建订阅向导,选择推送订阅方式(默认),74,4-3 SQL Server2005复制技术,4-3-4 “复制”的服务器配置,实验1:快照复制实验,(3)选择SERVER1实例中发布数据库school_fb后,进入新建订阅向导,选择推送订阅方式(默认),如图所示。选择发布服务器中的订阅数据库为school(如图所示),在随后弹出的分发代理安全性中点击按钮进入安全配置,75,4-3 SQL Server2005复制技术,4-3-4 “复制”的服务器配置,实验1:快照复制实验,(4)在安全设置界面中,选择在SQL Server代理账户下运行,连接订阅服务器中选择以SQL Server登录,76

48、,4-3 SQL Server2005复制技术,4-3-4 “复制”的服务器配置,注意:连接订阅服务器时候经常出现连接错误的情况,怎么办?,Sa用户是SQL Server的超级用户,可能的解决办法是: 由于Sa帐户未启用; 远程连接没有设为同时使用TCP/IP和Named Pipes 服务器身份验证选项为Windows身份验证模式,具体步骤参见安全性章节内容讲解。,77,4-3 SQL Server2005复制技术,4-3-4 “复制”的服务器配置,(5)完成安全设置任务后,点击下一步进入同步计划执行界面,设置代理计划为连续运行(如图所示)。而后配置初始化订阅属性,初始化时间为立即。在向导结束

49、时选择创建订阅,最后点击完成,结束订阅服务器的配置工作,78,4-3 SQL Server2005复制技术,4-3-4 “复制”的服务器配置,(6)测试复制实验。图4-67所示的两张表中,左侧表为SERVER1发布服务器的表数据,右侧表为SERVER2订阅服务器的表数据。右键点击发布服务器SERVER1的“重新初始化所有订阅”(如图4-68所示),并使用新快照和立即生成新快照,点击重新初始化后生成快照(如图4-69所示)。重新刷新SERVER2订阅服务器的本地订阅后,则两个服务器数据表保持同步,79,4-3 SQL Server2005复制技术,4-3-4 “复制”的服务器配置,复制后数据表保持同步效果,开始使用新快照和生成新快照,80,4-3 SQL Server2005复制技术,4-3-4 “复制”的服务器配置,实验2:事务复制实验,1. 第一步:在SERVER01上设置发布和分发 同配置快照复制基本一致,首先发布的类型为快照复制(如图4-71),同样选择数据库school数据库中的student表,其余步骤与快照服务完全相同。特别需要说明的是,在进行到“分发代理位置”步骤时候,必须选择推送订阅的方式而不能选择请求订阅的方式,否则无法进行初始化订阅,而导致事务复制失败。,81,4-3 SQL Server2005复制技术,4-3-4 “复制”的服务器配置,

展开阅读全文
相关资源
猜你喜欢
相关搜索
资源标签

当前位置:首页 > 实用文档 > 简明教程

本站链接:文库   一言   我酷   合作


客服QQ:2549714901微博号:道客多多官方知乎号:道客多多

经营许可证编号: 粤ICP备2021046453号世界地图

道客多多©版权所有2020-2025营业执照举报