码迷,mamicode.com
首页 > 数据库 > 详细

利用ODBC从SQLServer向Oracle中导数据

时间:2014-08-25 18:40:44      阅读:309      评论:0      收藏:0      [点我收藏+]

标签:blog   http   io   for   ar   数据   2014   代码   log   

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

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

3、打开Oracle数据库——工具——ODBC导入bubuko.com,布布扣

4、选择服务器,输入数据库账号和密码bubuko.com,布布扣

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

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 ‘+@table_name+‘(‘

/********3.取表的id*********/ DECLARE tbl_cursor CURSOR FOR select a.id from sys.sysobjects  a where a.id = object_id(N‘[dbo].[‘+@table_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 b.object_id=@table_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 @cons_sql=@cons_sql+@c_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

 

利用ODBC从SQLServer向Oracle中导数据

标签:blog   http   io   for   ar   数据   2014   代码   log   

原文地址:http://www.cnblogs.com/len0031/p/3914049.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!