将SQLServer2005中的数据同步到Oracle中

时间:2022-09-04 07:27:38

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

将SQLServer2005中的数据同步到Oracle中SELECT *
将SQLServer2005中的数据同步到Oracle中FROM msdb.dbo.MSdatatype_mappings
将SQLServer2005中的数据同步到Oracle中
将SQLServer2005中的数据同步到Oracle中SELECT *
将SQLServer2005中的数据同步到Oracle中FROM msdb.dbo.sysdatatypemappings

来查看SQLServer和其他数据库系统的数据类型对应关系。第一个SQL语句是看SQL转Oracle的类型对应,而第二个表则更详细得显示了各个数据库系统的类型对应。根据第一个表和我们的SQLServer中的字段类型我们就可以建立好Oracle表了。
ORACLE bigint NUMBER 19 3 1
将SQLServer2005中的数据同步到Oracle中ORACLE binary BLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中ORACLE binary RAW -1 4 1
将SQLServer2005中的数据同步到Oracle中ORACLE bit NUMBER 1 3 1
将SQLServer2005中的数据同步到Oracle中ORACLE char CHAR -1 4 1
将SQLServer2005中的数据同步到Oracle中ORACLE char CLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中ORACLE char VARCHAR2 -1 4 1
将SQLServer2005中的数据同步到Oracle中ORACLE datetime DATE NULL 0 1
将SQLServer2005中的数据同步到Oracle中ORACLE decimal NUMBER -1 3 1
将SQLServer2005中的数据同步到Oracle中ORACLE double precision FLOAT NULL 0 1
将SQLServer2005中的数据同步到Oracle中ORACLE float FLOAT NULL 0 1
将SQLServer2005中的数据同步到Oracle中ORACLE image BLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中ORACLE int NUMBER 10 3 1
将SQLServer2005中的数据同步到Oracle中ORACLE money NUMBER 19 3 1
将SQLServer2005中的数据同步到Oracle中ORACLE nchar NCHAR -1 4 1
将SQLServer2005中的数据同步到Oracle中ORACLE nchar NCLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中ORACLE ntext NCLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中ORACLE numeric NUMBER -1 3 1
将SQLServer2005中的数据同步到Oracle中ORACLE nvarchar NCLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中ORACLE nvarchar NVARCHAR2 -1 4 1
将SQLServer2005中的数据同步到Oracle中ORACLE nvarchar(max) NCLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中ORACLE real REAL NULL 0 1
将SQLServer2005中的数据同步到Oracle中ORACLE smalldatetime DATE NULL 0 1
将SQLServer2005中的数据同步到Oracle中ORACLE smallint NUMBER 5 3 1
将SQLServer2005中的数据同步到Oracle中ORACLE smallmoney NUMBER 10 3 1
将SQLServer2005中的数据同步到Oracle中ORACLE sysname NVARCHAR2 128 4 1
将SQLServer2005中的数据同步到Oracle中ORACLE text CLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中ORACLE timestamp RAW 8 4 1
将SQLServer2005中的数据同步到Oracle中ORACLE tinyint NUMBER 3 3 1
将SQLServer2005中的数据同步到Oracle中ORACLE uniqueidentifier CHAR 38 4 1
将SQLServer2005中的数据同步到Oracle中ORACLE varbinary BLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中ORACLE varbinary RAW -1 4 1
将SQLServer2005中的数据同步到Oracle中ORACLE varbinary(max) BLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中ORACLE varchar CLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中ORACLE varchar VARCHAR2 -1 4 1
将SQLServer2005中的数据同步到Oracle中ORACLE varchar(max) CLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中ORACLE xml NCLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中ORACLE bigint NUMBER 19 3 1
将SQLServer2005中的数据同步到Oracle中ORACLE binary BLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中ORACLE binary RAW -1 4 1
将SQLServer2005中的数据同步到Oracle中ORACLE bit NUMBER 1 3 1
将SQLServer2005中的数据同步到Oracle中ORACLE char CHAR -1 4 1
将SQLServer2005中的数据同步到Oracle中ORACLE char CLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中ORACLE char VARCHAR2 -1 4 1
将SQLServer2005中的数据同步到Oracle中ORACLE datetime DATE NULL 0 1
将SQLServer2005中的数据同步到Oracle中ORACLE decimal NUMBER -1 3 1
将SQLServer2005中的数据同步到Oracle中ORACLE double precision FLOAT NULL 0 1
将SQLServer2005中的数据同步到Oracle中ORACLE float FLOAT NULL 0 1
将SQLServer2005中的数据同步到Oracle中ORACLE image BLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中ORACLE int NUMBER 10 3 1
将SQLServer2005中的数据同步到Oracle中ORACLE money NUMBER 19 3 1
将SQLServer2005中的数据同步到Oracle中ORACLE nchar CHAR -1 4 1
将SQLServer2005中的数据同步到Oracle中ORACLE nchar CLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中ORACLE ntext CLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中ORACLE numeric NUMBER -1 3 1
将SQLServer2005中的数据同步到Oracle中ORACLE nvarchar CLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中ORACLE nvarchar VARCHAR2 -1 4 1
将SQLServer2005中的数据同步到Oracle中ORACLE nvarchar(max) CLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中ORACLE real REAL NULL 0 1
将SQLServer2005中的数据同步到Oracle中ORACLE smalldatetime DATE NULL 0 1
将SQLServer2005中的数据同步到Oracle中ORACLE smallint NUMBER 5 3 1
将SQLServer2005中的数据同步到Oracle中ORACLE smallmoney NUMBER 10 3 1
将SQLServer2005中的数据同步到Oracle中ORACLE sysname VARCHAR2 128 4 1
将SQLServer2005中的数据同步到Oracle中ORACLE text CLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中ORACLE timestamp RAW 8 4 1
将SQLServer2005中的数据同步到Oracle中ORACLE tinyint NUMBER 3 3 1
将SQLServer2005中的数据同步到Oracle中ORACLE uniqueidentifier CHAR 38 4 1
将SQLServer2005中的数据同步到Oracle中ORACLE varbinary BLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中ORACLE varbinary RAW -1 4 1
将SQLServer2005中的数据同步到Oracle中ORACLE varbinary(max) BLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中ORACLE varchar CLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中ORACLE varchar VARCHAR2 -1 4 1
将SQLServer2005中的数据同步到Oracle中ORACLE varchar(max) CLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中ORACLE xml CLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中ORACLE bigint NUMBER 19 3 1
将SQLServer2005中的数据同步到Oracle中ORACLE binary BLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中ORACLE binary RAW -1 4 1
将SQLServer2005中的数据同步到Oracle中ORACLE bit NUMBER 1 3 1
将SQLServer2005中的数据同步到Oracle中ORACLE char CHAR -1 4 1
将SQLServer2005中的数据同步到Oracle中ORACLE char CLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中ORACLE char VARCHAR2 -1 4 1
将SQLServer2005中的数据同步到Oracle中ORACLE datetime DATE NULL 0 1
将SQLServer2005中的数据同步到Oracle中ORACLE decimal NUMBER -1 3 1
将SQLServer2005中的数据同步到Oracle中ORACLE double precision FLOAT NULL 0 1
将SQLServer2005中的数据同步到Oracle中ORACLE float FLOAT NULL 0 1
将SQLServer2005中的数据同步到Oracle中ORACLE image BLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中ORACLE int NUMBER 10 3 1
将SQLServer2005中的数据同步到Oracle中ORACLE money NUMBER 19 3 1
将SQLServer2005中的数据同步到Oracle中ORACLE nchar NCHAR -1 4 1
将SQLServer2005中的数据同步到Oracle中ORACLE nchar NCLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中ORACLE ntext NCLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中ORACLE numeric NUMBER -1 3 1
将SQLServer2005中的数据同步到Oracle中ORACLE nvarchar NCLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中ORACLE nvarchar NVARCHAR2 -1 4 1
将SQLServer2005中的数据同步到Oracle中ORACLE nvarchar(max) NCLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中ORACLE real REAL NULL 0 1
将SQLServer2005中的数据同步到Oracle中ORACLE smalldatetime DATE NULL 0 1
将SQLServer2005中的数据同步到Oracle中ORACLE smallint NUMBER 5 3 1
将SQLServer2005中的数据同步到Oracle中ORACLE smallmoney NUMBER 10 3 1
将SQLServer2005中的数据同步到Oracle中ORACLE sysname NVARCHAR2 128 4 1
将SQLServer2005中的数据同步到Oracle中ORACLE text CLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中ORACLE timestamp RAW 8 4 1
将SQLServer2005中的数据同步到Oracle中ORACLE tinyint NUMBER 3 3 1
将SQLServer2005中的数据同步到Oracle中ORACLE uniqueidentifier CHAR 38 4 1
将SQLServer2005中的数据同步到Oracle中ORACLE varbinary BLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中ORACLE varbinary RAW -1 4 1
将SQLServer2005中的数据同步到Oracle中ORACLE varbinary(max) BLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中ORACLE varchar CLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中ORACLE varchar VARCHAR2 -1 4 1
将SQLServer2005中的数据同步到Oracle中ORACLE varchar(max) CLOB NULL 0 1
将SQLServer2005中的数据同步到Oracle中ORACLE xml NCLOB NULL 0 1

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

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

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

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

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

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

  创建一个sqlserver对sqlserver的数据库链接:

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

  创建一个sqlserver对Oracle的数据库链接:

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

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

  对于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中DELETE FROM MIS..MIS.CONTRACT_PROJECT
将SQLServer2005中的数据同步到Oracle中--清空Oracle表中的数据
将SQLServer2005中的数据同步到Oracle中INSERT into MIS..MIS.CONTRACT_PROJECT--将SQLServer中的数据写到Oracle中
将SQLServer2005中的数据同步到Oracle中SELECT contract_id,project_code,actual_money
将SQLServer2005中的数据同步到Oracle中FROM contract_project
将SQLServer2005中的数据同步到Oracle中

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

将SQLServer2005中的数据同步到Oracle中SELECT *
将SQLServer2005中的数据同步到Oracle中FROM MIS..MIS.CONTRACT_PROJECT

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

将SQLServer2005中的数据同步到Oracle中的更多相关文章

  1. excel文件与txt文件互转,并且把excel里的数据导入到oracle中

    一.excel文件转换成txt文件的步骤 a.首先要把excel文件转换成txt文件 1.Excel另存为中已经包含了TXT格式,所以我们可以直接将Excel表格另存为TXT格式,但是最后的效果好像不 ...

  2. C# .net 多线程中集合数据同步

    from:http://www.cnblogs.com/GavinCome/archive/2008/04/09/1145250.html C# .net 多线程中集合数据同步(转) 集合类通常不是线 ...

  3. 多线程查询数据,将结果存入到redis中,最后批量从redis中取数据批量插入数据库中【我】

    多线程查询数据,将结果存入到redis中,最后批量从redis中取数据批量插入数据库中 package com.xxx.xx.reve.service; import java.util.ArrayL ...

  4. 如何使用免费控件将Word表格中的数据导入到Excel中

    我通常使用MS Excel来存储和处理大量数据,但有时候经常会碰到一个问题—我需要的数据存储在word表格中,而不是在Excel中,这样处理起来非常麻烦,尤其是在数据比较庞大的时候, 这时我迫切地需要 ...

  5. C#-WinForm-ListView-表格式展示数据、如何将数据库中的数据展示到ListView中、如何对选中的项进行修改

    在展示数据库中不知道数量的数据时怎么展示最好呢?--表格 ListView - 表格形式展示数据 ListView 常用属性 HeaderStyle - "详细信息"视图中列标头的 ...

  6. c#.net循环将DataGridView中的数据赋值到Excel中,并设置样式

    Microsoft.Office.Interop.Excel.Application excel =                new Microsoft.Office.Interop.Excel ...

  7. phpexcel的写操作将数据库中的数据导入到excel中

    这个版本据说是可以支持excel2007,但是我使用2007编辑的xlsx是无法获得该库的支持.于是乎我就将它转化为2003.感觉支持地很好. 下面介绍一下具体的使用: require_once('. ...

  8. 使用OpenXml把Excel中的数据导出到DataSet中

    public class OpenXmlHelper { /// <summary> /// 读取Excel数据到DataSet中,默认读取所有Sheet中的数据 /// </sum ...

  9. 将Datagridview中的数据导出至Excel中

        首先添加一个模块ImportToExcel,并添加引用         然后导入命名空间: Imports Microsoft.Office.Interop Imports System.Da ...

随机推荐

  1. &lbrack;转&rsqb;Android App整体架构设计的思考

    1. 架构设计的目的 对程序进行架构设计的原因,归根到底是为了提高生产力.通过设计使程序模块化,做到模块内部的高聚合和模块之间的低耦合.这样做的好处是使得程序在开发的过程中,开发人员只需要专注于一点, ...

  2. Python脚本配合Linux计划任务工作

    经常遇到直接运行Python脚本没有问题,但是一放入/etc/crontab之后就歇菜的情况,总结了一下,大致需要注意以下几点: 1. 脚本首行加入#!/usr/bin/env python 2. 脚 ...

  3. Oracle数据库更新时间的SQL语句

    ---Oracle数据库更新时间字段数据时的sql语句---格式化时间插入update t_user u set u.name='pipi',u.modifytime=to_date('2015-10 ...

  4. ASP&period;NET控件Button (e&period;CommandArgument的使用方法)

    e.CommandArgument的使用方法 1. 在 Web 窗体页上显示普通按钮 (Button) 控件. <asp:Button id="MyButton" Text= ...

  5. keypress和keydown事件及keyCode和keyChar

    二:keypress和keydown事件: 现只在IE10.chrome(版本 32.0.1700.107 m).firefox(25.0.1)中测试了.   IE8 chrome firefox $ ...

  6. 主席树入门——询问区间第k大pos2104,询问区间&lt&semi;&equals;k的元素个数hdu4417

    poj2104找了个板子..,但是各种IO还可以进行优化 /* 找区间[l,r]第k大的数 */ #include<iostream> #include<cstring> #i ...

  7. 如何将字符串格式的对象转换成真正的js对象?

    1.如何将字符串格式的对象转换成真正的js对象? <script>//eval 的作用eval('var a = 100');console.log(a);</script> ...

  8. vue&plus;canvas踩坑之旅

    let img=new Image(); if(img.complete) { console.log('dd'); } img.src="http://localhost:8888/sta ...

  9. Java并发编程:CountDownLatch、CyclicBarrier和 Semaphore

    原文出处: 海子 在java 1.5中,提供了一些非常有用的辅助类来帮助我们进行并发编程,比如CountDownLatch,CyclicBarrier和Semaphore,今天我们就来学习一下这三个辅 ...

  10. u-boot移植(七)---代码修改---存储控制器

    一.CPU访问芯片的条件 CPU通过访问存储控制器,来读取外部设备的数据. CPU想访问一个芯片,需要如下条件(配置信息): 地址线 数据线:8位/16位/32位数据宽度 时钟/频率 其他芯片相关的特 ...