利用ODBC从SQLServer向Oracle中导数据

1、首先要在Oracle数据库中建对应的表,Oracle数据库中的字段类型和Sql Server 有所不同,Oracle中常用的有varchar2、integer、nchar、date,Sql Server 的字段类型相对多一些,uniqueidentifier类型的长度是36。

2、打开管理工具——数据源(ODBC),配置SqlServer的数据源。

3、打开Oracle数据库——工具——ODBC导入

4、选择服务器,输入数据库账号和密码

5、选择用户和表,然后点击左下角的导入按钮即可

6、附上由SqlServer表自动生成Oracle的代码:

/********1.定义变量*********/ DECLARE @table_id int, @table_name varchar(100), @column_id int, @c_name sysname, @c_type varchar(50), @max_length smallint, @precision tinyint, @scale tinyint, @is_nullable bit, @cons_sql varchar(5000)

/********2.变量初始化*********/ set @table_name=‘mio_log‘ set @cons_sql=‘create table ‘[email protected]_name+‘(‘

/********3.取表的id*********/ DECLARE tbl_cursor CURSOR FOR select a.id from sys.sysobjects  a where a.id = object_id(N‘[dbo].[‘[email protected]_name+‘]‘) and OBJECTPROPERTY(id, N‘IsUserTable‘) = 1

OPEN tbl_cursor FETCH NEXT FROM tbl_cursor INTO @table_id

/********4.构建表的结构*********/ DECLARE columns_cursor CURSOR FOR SELECT b.column_id,b.name,c.name,b.max_length, b.precision,b.scale,b.is_nullable from sys.columns b,sys.systypes c where [email protected]_id and b.system_type_id=c.xtype order by b.column_id asc

OPEN columns_cursor

FETCH NEXT FROM columns_cursor INTO @column_id, @c_name, @c_type, @max_length, @precision, @scale, @is_nullable

WHILE @@FETCH_STATUS = 0 BEGIN set @[email protected][email protected]_name+‘ ‘+ (case when @c_type in(‘smallint‘,‘tinyint‘) then ‘int‘ when @c_type=‘int‘ then ‘number‘ when @c_type =‘varchar‘ then ‘varchar2(‘+convert(varchar(2),@max_length)+‘)‘ when @c_type in(‘datetime‘,‘smalldatetime‘) then ‘date‘ when @c_type=‘decimal‘ then ‘number‘+‘(‘+convert(varchar(1),@precision)+‘,‘+convert(varchar(1),@scale)+‘)‘ when @c_type=‘char‘ then ‘char(‘+convert(varchar(2),@max_length)+‘)‘ when @c_type=‘text‘ then ‘long‘ --此处有待于进一步数据类型的映射 else ‘##‘ end)+ (case when @is_nullable=1 then ‘ null‘ else ‘ not null‘ end)+‘,‘ FETCH NEXT FROM columns_cursor INTO @column_id, @c_name, @c_type, @max_length, @precision, @scale, @is_nullable END

/********5.输出建表语句*********/ select left(@cons_sql,Len(@cons_sql)-1)+‘);‘

/********6.释放游标*********/ DEALLOCATE tbl_cursor DEALLOCATE columns_cursor

时间: 2024-08-09 00:17:26

利用ODBC从SQLServer向Oracle中导数据的相关文章

利用Kettle进行SQLServer与Oracle之间的数据迁移实践

Kettle简介 Kettle(网地址为http://kettle.pentaho.org/)是一款国外开源的ETL工具,纯java编写,可以在Windows.Linux.Unix上运行,数据抽取高效稳定. Kettle 中文名称叫水壶,该项目的主程序员MATT 希望把各种数据放到一个壶里,然后以一种指定的格式流出.Kettle中有两种脚本文件,transformation和job,transformation完成针对数据的基础转换,job则完成整个工作流的控制. Windows环境下的安装与配

SQLServer与Oracle的数据同步(触发器trigger)

说到同步,其实是靠"作业"定时调度存储过程来操作数据,增,删,改,全在里面,结合触发器,游标来实现,关于作业调度,使用了5秒运行一次来实行"秒级作业",这样基本就算比较快的"同步" 做的是SQL Server往Oracle端同步,先在sql server上建立往Oracle端的链接服务器,我用一个视图"封装"了一下链接服务器下的一张表. create view v_ora_PUBLISHLASTREC as select *

python 编写 SQLSERVER,ORACLE,MYSQL 数据查询及插入数据

SQLSERVER方法: 插入数据代码演示(上下文管理器方法): import pymssql,uuidfrom class_area.class_ReadConf import ReadDate #导入读取配置文件模块方法sql_data=ReadDate('sqlserver.conf','DATABASE','config').readdata() read_data=ReadDate('area.conf','AREAS','config').readdata()area_read_2=

SqlServer 、Oracle 、MySql 的区别

一.sqlserver 优点: 易用性.适合分布式组织的可伸缩性.用于决策支持的数据仓库功能.与许多其他服务器软件紧密关联的集成性.良好的性价比等: 为数据管理与分析带来了灵活性,允许单位在快速变化的环境中从容响应,从而获得竞争优势.从数据管理和分析角度看,将原始数据转化为商业智能和充分利用Web带来的机会非常重要.作为一个完备的数据库和数据分析包,SQLServer为快速开发新一代企业级商业应用程序.为企业赢得核心竞争优势打开了胜利之门.作为重要的基准测试可伸缩性和速度奖的记录保持者,SQLS

LoadRunner利用ODBC编写MySql脚本

分类: 4.软件设计/架构/测试 2010-01-08 17:48 5635人阅读 评论(3) 收藏 举报 loadrunnermysql脚本数据库sqlserver测试 最近做了几周的LoadRunner测试,有一些心得,记录下来,以便以后查找. LoadRunner测试数据库是模拟客户端去连接数据库服务器,因此,需要协议(或者说驱动的支持).LoadRunner本身直接支持Oracle. SqlServer数据库,这两个数据库直接选择相应的协议就可以录制脚本.而MySql数据库只能利用ODB

关于sqlserver和oracle的一点感受

2012年使用了一点oracle,那个时候其实并不真正的了解这个数据库,所会的也就是利用toad做一些简单的管理,后来转战到sqlserver才开始对数据库这个东西有了一些了解.使用了sqlserver有一年多了,后来又开始使用了oracle了,让我一阵须臾,这回多少也该弄懂了oracle这个大大了吧,经过我的使用还真是发现了一些不同. sqlserver在存储中使用了不少的临时表,因为这有助于管理好数据的edit,但是这个方法在oracle中确实很少见的,因为对于oracle来说,临时表的建立

LoadRunner利用ODBC编写MySql脚本(转)

LoadRunner测试数据库是模拟客户端去连接数据库服务器,因此,需要协议(或者说驱动的支持).LoadRunner本身直接支持Oracle.SqlServer数据库,这两个数据库直接选择相应的协议就可以录制脚本.而MySql数据库只能利用ODBC协议来录制(编写)脚本,所以必须要MySql的ODBC驱动,和支持ODBC的查询分析器(录脚本需要,自己编写就不需要). 1.首先要安装MySql的ODBC驱动,MyODBC 3.51.11 WIN. 2.从“控制面板”打开“数据源ODBC”,如果没

利用SHELL脚本来验证Oracle数据库RMAN备份集的有效性

利用SHELL脚本来验证Oracle数据库RMAN备份集的有效性 作者:赵全文  网名:guestart 我们生产环境的Oracle数据库都做了RMAN备份,是采用了一周的RMAN备份保留策略:除了使用RMAN备份以外,我们还使用了爱数(Eisoo)备份软件来进行备份,可以说是做到了有备无患.可是,如果有一天,Oracle数据库由于主机层面硬件原因或是数据库层面的原因不能对外提供高可用服务的时候,假设数据丢了一大部分,我们只有用RMAN备份来进行恢复,再如果发现,RMAN备份失效了,那就往地缝里

怎样利用JDBC连接并操作Oracle数据库

之前学习.NET的时候.以前利用ODBC进行连接数据库,而在Java中通常採用JDBC连接数据库,这里以oracle数据库为例简单的总结一下利用JDBC怎样连接并操作数据库. 1.连接 public class DbUtil { public static Connection getConnection(){ Connection conn=null; try { Class.forName("oracle.jdbc.driver.OracleDriver");//找到oracle驱