首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

利用SQLServer2005复制功能实现与Oracle数据库同步

在项目中经常会遇到一个项目操作几个数据库的情况,若是同种类型的数据库也还好说,可以直接链接两个数据库,也可以用数据库的同步功能。若我们的项目使用SQLServer2005进行开发,而且项目中要用到Oracle数据库中的数据,那么又该怎么实现拉?一般来说方案有以下几种。 1.分别建立链接对数据库进行操作,SQLServer可以用ADO.NET,操作Oracle可以用OLEDB或者用System.Data.OracleClient(需要添加引用才能用) 这种方案的优点就是简单,各自写各自的数据库操作代码,缺点就是不能将两个数据库中的表直接进行联合查询,链接Oracle的每台机器必须安装OracleClient才可以使用。 2.使用同义词操作Oracle数据库。 这种方法的具体操作我在以前的文章中已经写清楚了,这样做一来可以进行表的联合查询二来不需要每台机器都安装OracleClient,但是还是有一个缺点:效率低,比如对同义词使用like去查找需要的数据,如果是直接连Oracle数据库也许只要0.1秒就可以找到答案,但是用同义词可能就要等10秒20秒或更久。原来SQLServer并不是直接把查询语句传递给Oracle,让Oracle执行操作,而是将所有数据都取到SQLServer服务器上,边取数据边分析,直到满足查询条件为止。其实这种数据放在两个服务器上还有一个缺点就是一旦Oracle服务器宕机,即使我们这边的所有服务器都是好的,那么我们的程序中用到Oracle数据的地方就无法使用。 3.直接链接Oracle数据库+同义词+作业+异常跳转 方式。 这种方法具体讲就是我们的程序直接用OLEDB(OracleClient)链接Oracle数据库,同时SQLServer服务器也建立了同义词指向Oracle,在SQLServer上建立作业,将同义词中的数据拷贝到SQLServer服务器的表中。一旦Oracle宕机,程序中就会捕捉到异常,于是就使用SQLServer中的数据。这样做比较复杂,需要一定的编程,效率也不是特别高,但是优点也是明细的,平时链接Oralce服务器,异常情况下链接SQLServer中的备份数据,保证了程序的正常运行。 4.直接编写一个程序,以服务或自启动方式一直运行,每隔一段时间将Oracle数据库中的数据写到SQLServer数据库中。 这种方法就是编程复杂,具有很大难度。 5.利用SQLServer2005的复制功能将Oracle数据库中的数据同步到SQLServer服务器中,程序只操作SQLServer,不链接Oracle数据库。 这种方法不需要编写任何代码,由于只对SQLServer进行查询,所以查询效率高可以做多表链接,开发人员也不需要再装OracleClient,也不用害怕Oracle服务器宕机导致我们的相关程序无法使用。优点倒是很多,那么有没有缺点拉?缺点还是有的,主要是取得的数据不是实时的数据,Oracle那边的数据更新了,我们这边还有可能是老数据。 前面的四种方法我就不用多讲了,这次主要是讲第五种方法的具体实现:

01

互联网+ 何人能挡?带着你的Code飞奔吧!

SQLServer性能优化专题 01.SQLServer性能优化之----强大的文件组----分盘存储(水平分库) http://www.cnblogs.com/dunitian/p/5276431.html 02.SQLServer性能优化之---水平分库扩展 http://www.cnblogs.com/dunitian/p/6078512.html 03.SQLServer性能优化之---分表分库技术--(同义词+链接服务器) http://www.cnblogs.com/dunitian/p/6041745.html 04.SQLServer性能优化之---读写分离&数据同步(发布订阅) http://www.cnblogs.com/dunitian/p/6041758.html 05.换环境了,以后继续更 06.备份,07.xxxx,08.故障转移 09.SQLServer性能优化之---数据库级日记监控(XEVENT) http://www.cnblogs.com/dunitian/p/6022967.html 很久以前: 我为NET狂官方面试题-数据库篇 http://www.cnblogs.com/dunitian/p/6028838.html 我为NET狂官方面试题-数据库篇答案 http://www.cnblogs.com/dunitian/p/6041323.html 01.有朋友问了数据库ID不连续,怎么获取上下篇文章?(不是所有情况都适用) http://www.cnblogs.com/dunitian/p/5239049.html 01.在sql server中建存储过程,如果需要参数是一个可变集合怎么处理? http://www.cnblogs.com/dunitian/p/4501268.html 02.把插入的数据自动备份到另一个表中 ~ 语境:本地和服务器自动同步(非数据同步解决方案) http://www.cnblogs.com/dunitian/p/5367445.html 03.SQL:指定名称查不到数据的衍伸~空格 换行符 回车符的批量处理 http://www.cnblogs.com/dunitian/p/5416429.html 04.利用SQLServer数据库发送邮件 http://www.cnblogs.com/dunitian/p/6022826.html 05.SQL Server 无法连接到服务器。SQL Server 复制需要有实际的服务器名称才能连接到服务器。请指定实际的服务器名称。 http://www.cnblogs.com/dunitian/p/6041824.html 06."无法删除数据库,因为该数据库当前正在使用"问题解决 http://www.cnblogs.com/dunitian/p/6047760.html 07.SQLServer文件收缩-图形化+命令 http://www.cnblogs.com/dunitian/p/6047709.html 08.关于全局ID,雪花(snowflake)算法的说明 http://www.cnblogs.com/dunitian/p/6130543.html 09.数据库分离附加(附日记丢失的处理) http://www.cnblogs.com/dunitian/p/6165945.html 10.数据库改名系列(数据库名,逻辑名,物理文件名) http://www.cnblogs.com/dunitian/p/6165998.html 11.牛逼的OSQL----大数据导入(cmd) http://www.cnblogs.com/dunitian/p/5276449.html 12.【SQLServer】记一次数据迁移-标识重复的简单处理 http://www.cnblogs.com/dunitian/p/6195827.html 13.【恢复挂起的解决方案】附加文件时候的提示“无法重新生成日志,原因是数据库关闭时存在打开的事务/用户,该数据库没有检查点或者该数据库是只读的。 ”【数据库恢复】 http://www.cnblogs.com/dunitian/p/6197051.html 14.数据库备份相关 http://www.cnblogs.com/dunitian/p/6260481.html

07
领券