有时由于项目开发的需要,必须将SQLServer2005中的某些表同步到Oracle数据库中,由其他其他系统来读取这些数据。不同数据库类型之间的数据同步我们可以使用链接服务器和SQLAgent来实现。假设我们这边(SQLServer2005)有一个合同管理系统,其中有表contract contract_project是需要同步到一个MIS系统中的(Oracle9i)那么,我们可以按照以下几步实现数据库的同步。
1.
Oracle中建立对应的contract contract_project表,需要同步哪些字段我们就建那些字段到Oracle表中。
这里需要注意的是Oracle的数据类型和SQLServer的数据类型是不一样的,那么他们之间是什么样的关系拉?我们可以在SQLServer下运行:

将SQLServer2005中的数据同步到Oracle中_OracleSELECT *
将SQLServer2005中的数据同步到Oracle中_Oracle_02FROM msdb.dbo.MSdatatype_mappings
将SQLServer2005中的数据同步到Oracle中_Oracle_03
将SQLServer2005中的数据同步到Oracle中_Oracle_04SELECT *
将SQLServer2005中的数据同步到Oracle中_Oracle_05FROM msdb.dbo.sysdatatypemappings

来查看SQLServer和其他数据库系统的数据类型对应关系。第一个SQL语句是看SQLOracle的类型对应,而第二个表则更详细得显示了各个数据库系统的类型对应。根据第一个表和我们的SQLServer中的字段类型我们就可以建立好Oracle表了。
ORACLE bigint NUMBER 19 3 1
将SQLServer2005中的数据同步到Oracle中_Oracle_06ORACLE binary BLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中_Oracle_07ORACLE binary RAW -1 4 1
将SQLServer2005中的数据同步到Oracle中_Oracle_08ORACLE bit NUMBER 1 3 1
将SQLServer2005中的数据同步到Oracle中_Oracle_09ORACLE char CHAR -1 4 1
将SQLServer2005中的数据同步到Oracle中_Oracle_10ORACLE char CLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中_Oracle_11ORACLE char VARCHAR2 -1 4 1
将SQLServer2005中的数据同步到Oracle中_Oracle_12ORACLE datetime DATE NULL 0 1
将SQLServer2005中的数据同步到Oracle中_Oracle_13ORACLE decimal NUMBER -1 3 1
将SQLServer2005中的数据同步到Oracle中_Oracle_14ORACLE double precision FLOAT NULL 0 1
将SQLServer2005中的数据同步到Oracle中_Oracle_15ORACLE float FLOAT NULL 0 1
将SQLServer2005中的数据同步到Oracle中_Oracle_16ORACLE image BLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中_Oracle_17ORACLE int NUMBER 10 3 1
将SQLServer2005中的数据同步到Oracle中_Oracle_18ORACLE money NUMBER 19 3 1
将SQLServer2005中的数据同步到Oracle中_Oracle_19ORACLE nchar NCHAR -1 4 1
将SQLServer2005中的数据同步到Oracle中_Oracle_20ORACLE nchar NCLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中_Oracle_21ORACLE ntext NCLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中_Oracle_22ORACLE numeric NUMBER -1 3 1
将SQLServer2005中的数据同步到Oracle中_Oracle_23ORACLE nvarchar NCLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中_Oracle_24ORACLE nvarchar NVARCHAR2 -1 4 1
将SQLServer2005中的数据同步到Oracle中_Oracle_25ORACLE nvarchar(max) NCLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中_Oracle_26ORACLE real REAL NULL 0 1
将SQLServer2005中的数据同步到Oracle中_Oracle_27ORACLE smalldatetime DATE NULL 0 1
将SQLServer2005中的数据同步到Oracle中_Oracle_28ORACLE smallint NUMBER 5 3 1
将SQLServer2005中的数据同步到Oracle中_Oracle_29ORACLE smallmoney NUMBER 10 3 1
将SQLServer2005中的数据同步到Oracle中_Oracle_30ORACLE sysname NVARCHAR2 128 4 1
将SQLServer2005中的数据同步到Oracle中_Oracle_31ORACLE text CLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中_Oracle_32ORACLE timestamp RAW 8 4 1
将SQLServer2005中的数据同步到Oracle中_Oracle_33ORACLE tinyint NUMBER 3 3 1
将SQLServer2005中的数据同步到Oracle中_Oracle_34ORACLE uniqueidentifier CHAR 38 4 1
将SQLServer2005中的数据同步到Oracle中_Oracle_35ORACLE varbinary BLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中_Oracle_36ORACLE varbinary RAW -1 4 1
将SQLServer2005中的数据同步到Oracle中_Oracle_37ORACLE varbinary(max) BLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中_Oracle_38ORACLE varchar CLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中_Oracle_39ORACLE varchar VARCHAR2 -1 4 1
将SQLServer2005中的数据同步到Oracle中_Oracle_40ORACLE varchar(max) CLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中_Oracle_41ORACLE xml NCLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中_Oracle_42ORACLE bigint NUMBER 19 3 1
将SQLServer2005中的数据同步到Oracle中_Oracle_43ORACLE binary BLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中_Oracle_44ORACLE binary RAW -1 4 1
将SQLServer2005中的数据同步到Oracle中_Oracle_45ORACLE bit NUMBER 1 3 1
将SQLServer2005中的数据同步到Oracle中_Oracle_46ORACLE char CHAR -1 4 1
将SQLServer2005中的数据同步到Oracle中_Oracle_47ORACLE char CLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中_Oracle_48ORACLE char VARCHAR2 -1 4 1
将SQLServer2005中的数据同步到Oracle中_Oracle_49ORACLE datetime DATE NULL 0 1
将SQLServer2005中的数据同步到Oracle中_Oracle_50ORACLE decimal NUMBER -1 3 1
将SQLServer2005中的数据同步到Oracle中_Oracle_51ORACLE double precision FLOAT NULL 0 1
将SQLServer2005中的数据同步到Oracle中_Oracle_52ORACLE float FLOAT NULL 0 1
将SQLServer2005中的数据同步到Oracle中_Oracle_53ORACLE image BLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中_Oracle_54ORACLE int NUMBER 10 3 1
将SQLServer2005中的数据同步到Oracle中_Oracle_55ORACLE money NUMBER 19 3 1
将SQLServer2005中的数据同步到Oracle中_Oracle_56ORACLE nchar CHAR -1 4 1
将SQLServer2005中的数据同步到Oracle中_Oracle_57ORACLE nchar CLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中_Oracle_58ORACLE ntext CLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中_Oracle_59ORACLE numeric NUMBER -1 3 1
将SQLServer2005中的数据同步到Oracle中_Oracle_60ORACLE nvarchar CLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中_Oracle_61ORACLE nvarchar VARCHAR2 -1 4 1
将SQLServer2005中的数据同步到Oracle中_Oracle_62ORACLE nvarchar(max) CLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中_Oracle_63ORACLE real REAL NULL 0 1
将SQLServer2005中的数据同步到Oracle中_Oracle_64ORACLE smalldatetime DATE NULL 0 1
将SQLServer2005中的数据同步到Oracle中_Oracle_65ORACLE smallint NUMBER 5 3 1
将SQLServer2005中的数据同步到Oracle中_Oracle_66ORACLE smallmoney NUMBER 10 3 1
将SQLServer2005中的数据同步到Oracle中_Oracle_67ORACLE sysname VARCHAR2 128 4 1
将SQLServer2005中的数据同步到Oracle中_Oracle_68ORACLE text CLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中_Oracle_69ORACLE timestamp RAW 8 4 1
将SQLServer2005中的数据同步到Oracle中_Oracle_70ORACLE tinyint NUMBER 3 3 1
将SQLServer2005中的数据同步到Oracle中_Oracle_71ORACLE uniqueidentifier CHAR 38 4 1
将SQLServer2005中的数据同步到Oracle中_Oracle_72ORACLE varbinary BLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中_Oracle_73ORACLE varbinary RAW -1 4 1
将SQLServer2005中的数据同步到Oracle中_Oracle_74ORACLE varbinary(max) BLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中_Oracle_75ORACLE varchar CLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中_Oracle_76ORACLE varchar VARCHAR2 -1 4 1
将SQLServer2005中的数据同步到Oracle中_Oracle_77ORACLE varchar(max) CLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中_Oracle_78ORACLE xml CLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中_Oracle_79ORACLE bigint NUMBER 19 3 1
将SQLServer2005中的数据同步到Oracle中_Oracle_80ORACLE binary BLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中_Oracle_81ORACLE binary RAW -1 4 1
将SQLServer2005中的数据同步到Oracle中_Oracle_82ORACLE bit NUMBER 1 3 1
将SQLServer2005中的数据同步到Oracle中_Oracle_83ORACLE char CHAR -1 4 1
将SQLServer2005中的数据同步到Oracle中_Oracle_84ORACLE char CLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中_Oracle_85ORACLE char VARCHAR2 -1 4 1
将SQLServer2005中的数据同步到Oracle中_Oracle_86ORACLE datetime DATE NULL 0 1
将SQLServer2005中的数据同步到Oracle中_Oracle_87ORACLE decimal NUMBER -1 3 1
将SQLServer2005中的数据同步到Oracle中_Oracle_88ORACLE double precision FLOAT NULL 0 1
将SQLServer2005中的数据同步到Oracle中_Oracle_89ORACLE float FLOAT NULL 0 1
将SQLServer2005中的数据同步到Oracle中_Oracle_90ORACLE image BLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中_Oracle_91ORACLE int NUMBER 10 3 1
将SQLServer2005中的数据同步到Oracle中_Oracle_92ORACLE money NUMBER 19 3 1
将SQLServer2005中的数据同步到Oracle中_Oracle_93ORACLE nchar NCHAR -1 4 1
将SQLServer2005中的数据同步到Oracle中_Oracle_94ORACLE nchar NCLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中_Oracle_95ORACLE ntext NCLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中_Oracle_96ORACLE numeric NUMBER -1 3 1
将SQLServer2005中的数据同步到Oracle中_Oracle_97ORACLE nvarchar NCLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中_Oracle_98ORACLE nvarchar NVARCHAR2 -1 4 1
将SQLServer2005中的数据同步到Oracle中_Oracle_99ORACLE nvarchar(max) NCLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中_Oracle_100ORACLE real REAL NULL 0 1
将SQLServer2005中的数据同步到Oracle中_Oracle_101ORACLE smalldatetime DATE NULL 0 1
将SQLServer2005中的数据同步到Oracle中_Oracle_102ORACLE smallint NUMBER 5 3 1
将SQLServer2005中的数据同步到Oracle中_Oracle_103ORACLE smallmoney NUMBER 10 3 1
将SQLServer2005中的数据同步到Oracle中_Oracle_104ORACLE sysname NVARCHAR2 128 4 1
将SQLServer2005中的数据同步到Oracle中_Oracle_105ORACLE text CLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中_Oracle_106ORACLE timestamp RAW 8 4 1
将SQLServer2005中的数据同步到Oracle中_Oracle_107ORACLE tinyint NUMBER 3 3 1
将SQLServer2005中的数据同步到Oracle中_Oracle_108ORACLE uniqueidentifier CHAR 38 4 1
将SQLServer2005中的数据同步到Oracle中_Oracle_109ORACLE varbinary BLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中_Oracle_110ORACLE varbinary RAW -1 4 1
将SQLServer2005中的数据同步到Oracle中_Oracle_111ORACLE varbinary(max) BLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中_Oracle_112ORACLE varchar CLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中_Oracle_113ORACLE varchar VARCHAR2 -1 4 1
将SQLServer2005中的数据同步到Oracle中_Oracle_114ORACLE varchar(max) CLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中_Oracle_115ORACLE xml NCLOB NULL 0 1

2.建立链接服务器。我们将Oracle系统作为SQLServer的链接服务器加入到SQLServer中。

       SqlServer下数据库链接的使用方法

       有时候我们希望在一个sqlserver下访问另一个sqlserver数据库上的数据,或者访问其他oracle数据库上的数据,要想完成这些操作,我们首要的是创建数据库链接。

  数据库链接能够让本地的一个sqlserver登录用户映射到远程的一个数据库服务器上,并且像操作本地数据库一样。那么怎么创建数据库链接呢?我现在有两种方法可以实现。

  第一种:在 sqlserver 企业管理器中,建立,这个比较简单的,首先在 "服务器对象"节点下的数据库链接节点 上点右键 ,在出现的菜单中点 新建数据库链接 ,然后会弹出一个界面,需要我们填写的有:链接服务器(这是一个名字,自己根据情况自行定义,以后就要通过他进行远程访问了),提供程序名称(这个就是选择数据驱动,根据数据库类型来选择,不能乱选,否则链接不上的),数据源(对于sqlserver就是远程数据库服务器的主机名或者IP,对于 oracle 就是在 oracle net config 中配置的别名),安全上下文用户和口令(也就是远程服务器的用户和口令)。

  第二种:利用系统存储过程

  创建一个sqlserversqlserver的数据库链接:

exec sp_addlinkedserver  'link_northsnow','','SQLOLEDB','远程服务器主机名或域名或ip地址'
exec sp_addlinkedsrvlogin 'link_northsnow','false',null,'
用户名','用户口令
'

  创建一个sqlserverOracle的数据库链接:

exec sp_addlinkedserver 'link_ora', 'Oracle', 'MSDAORA', 'oracle数据库服务器别名'
exec sp_addlinkedsrvlogin 'link_ora', false, 'sa', '
用户名', '用户口令
'

  有了数据库链接我们就可以使用了。对于sqlserveroracle中的使用方法是有区别的。

  对于sqlserver

create view v_lhsy_user as select * from link_northsnow.lhsy.dbo.sys_user
select * from v_lhsy_user
其中lhsy为远程的数据库名
sys_user
为表名

  对于 oracle

create view vvv as select * from link_ora..NORTHSNOW.SYS_USER
select * from vvv;
其中northsnow为远程oracle数据库服务器的一个用户名,SYS_USER为该用户在该服务器上的一个表,要非常注意的是:数据库链接(link_ora)后面有两个点(..),再往后面必须全部大写,查询的对象一般为表格或者视图,不能查询同义词。

  要想删除数据库链接,也有两种方法,

  一种是在企业管理器中操作,这个简单。

  另一种是用系统存储过程:

  exec sp_dropserver  数据库链接名称,'droplogins'

3.使用SQL语句通过链接服务器将SQLServer数据写入Oracle中。
比如我们建立了链接服务器MIS,而Oracle中在MIS用户下面建立了表contract_project,那么我们的SQL语句就是:

将SQLServer2005中的数据同步到Oracle中_Oracle_116DELETE FROM MIS..MIS.CONTRACT_PROJECT
将SQLServer2005中的数据同步到Oracle中_Oracle_117--
清空Oracle表中的数据
将SQLServer2005中的数据同步到Oracle中_Oracle_118INSERT into MIS..MIS.CONTRACT_PROJECT--
SQLServer中的数据写到Oracle

将SQLServer2005中的数据同步到Oracle中_Oracle_119SELECT contract_id,project_code,actual_money
将SQLServer2005中的数据同步到Oracle中_Oracle_120FROM contract_project

将SQLServer2005中的数据同步到Oracle中_Oracle_121

如果报告成功,那么我们的数据就已经写入到Oracle中了。用

将SQLServer2005中的数据同步到Oracle中_Oracle_122SELECT *
将SQLServer2005中的数据同步到Oracle中_Oracle_123FROM MIS..MIS.CONTRACT_PROJECT

查看Oracle数据库中是否已经有数据了。
4.
建立SQLAgent,将以上同步SQL语句作为执行语句,每天定时同步两次。
这样我们的同步就完成了。
这里需要注意的是MIS..MIS.CONTRACT_PROJECT 这里必须要大写,如果是小写的话会造成同步失败。