欢迎来到天天文库
浏览记录
ID:40512627
大小:17.79 KB
页数:4页
时间:2019-08-03
《利用SQLServer2005复制功能实现与Oracle数据库同步方法》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、利用SQLServer2005复制功能实现与Oracle数据库同步在项目中经常会遇到一个项目操作几个数据库的情况,若是同种类型的数据库也还好说,可以直接链接两个数据库,也可以用数据库的同步功能。若我们的项目使用SQLServer2005进行开发,而且项目中要用到Oracle数据库中的数据,那么又该怎么实现拉?一般来说方案有以下几种。1.分别建立链接对数据库进行操作,SQLServer可以用ADO.NET,操作Oracle可以用OLEDB或者用System.Data.OracleClient(需要添加引用才能用)这种方案的优点就是
2、简单,各自写各自的数据库操作代码,缺点就是不能将两个数据库中的表直接进行联合查询,链接Oracle的每台机器必须安装OracleClient才可以使用。2.使用同义词操作Oracle数据库。这种方法的具体操作我在以前的文章中已经写清楚了,这样做一来可以进行表的联合查询,二来不需要每台机器都安装OracleClient,但是还是有一个缺点:效率低,比如对同义词使用like去查找需要的数据,如果是直接连Oracle数据库也许只要0.1秒就可以找到答案,但是用同义词可能就要等10秒20秒或更久。原来SQLServer并不是直接把查询语
3、句传递给Oracle,让Oracle执行操作,而是将所有数据都取到SQLServer服务器上,边取数据边分析,直到满足查询条件为止。其实这种数据放在两个服务器上还有一个缺点就是一旦Oracle服务器宕机,即使我们这边的所有服务器都是好的,那么我们的程序中用到Oracle数据的地方就无法使用。3.直接链接Oracle数据库+同义词+作业+异常跳转方式。这种方法具体讲就是我们的程序直接用OLEDB(OracleClient)链接Oracle数据库,同时SQLServer服务器也建立了同义词指向Oracle,在SQLServer上建立
4、作业,将同义词中的数据拷贝到SQLServer服务器的表中。一旦Oracle宕机,程序中就会捕捉到异常,于是就使用SQLServer中的数据。这样做比较复杂,需要一定的编程,效率也不是特别高,但是优点也是明细的,平时链接Oralce服务器,异常情况下链接SQLServer中的备份数据,保证了程序的正常运行。4.直接编写一个程序,以服务或自启动方式一直运行,每隔一段时间将Oracle数据库中的数据写到SQLServer数据库中。这种方法就是编程复杂,具有很大难度。5.利用SQLServer2005的复制功能将Oracle数据库中的
5、数据同步到SQLServer服务器中,程序只操作SQLServer,不链接Oracle数据库。这种方法不需要编写任何代码,由于只对SQLServer进行查询,所以查询效率高可以做多表链接,开发人员也不需要再装OracleClient,也不用害怕Oracle服务器宕机导致我们的相关程序无法使用。优点倒是很多,那么有没有缺点拉?缺点还是有的,主要是取得的数据不是实时的数据,Oracle那边的数据更新了,我们这边还有可能是老数据。前面的四种方法我就不用多讲了,这次主要是讲第五种方法的具体实现:1.安装SQLServer复制功能。在安装
6、SQLServer数据库的时候选上“复制”,将“复制”功能安装到服务器。微软说如果第一次安装的时候没有装,以后再想添加该功能只需要运行安装程序将“复制”选上就可以了,不过说是这么说,我试了几次都不行,我也不知道怎么回事,为了安装上复制,所以将SQLServer卸载了,重新安装!这种方法很笨,不过我实现想不出其他办法了,希望高手指点。2.设置Oracle服务器端的权限。创建一个用于复制用的用户,授予下列权限:CREATEPUBLICSYNONYM和DROPPUBLICSYNONYMCREATEPROCEDURECREATESEQU
7、ENCECREATESESSION还必须直接为用户授予下列权限(不是通过角色):CREATEANYTRIGGER。CREATETABLECREATEVIEW同时该用户还必须对要发布的表所在表空间有UNLIMITED的权限,还要针对每个要用于同步的表设置Select权限。3.SQLServer服务器上安装OracleClient10g必须安装了才可以链接Oracle服务器,不推荐安装Oracle9i,即使我们要链接的Oracle是9i的。安装完成以后重启SQLServer服务器。用PLSQL或其他工具测试一下是否可以链接到Orac
8、le服务器。4.设置SQLServerAgent权限在SQLServer服务器上新建用户,将该用户加为管理员,在“服务”中找到“SQLServerAgent”,将其启动用户改为该用户,重启该服务。5.配置分发打开ManagementStudio右键“复制”节点,
此文档下载收益归作者所有