1.前言
由于工作需要,需将oracle的数据导入到sqlserver2008,经同事推荐使用kettle工具。
2.kettle简介
kettle是一款国外开源的etl工具,纯java编写,绿色无需安装,数据抽取高效稳定。
kettle中有两种脚本文件,transformation和job,transformation完成针对数据的基础转换,job则完成整个工作流的控制。
这里我们只用transformation完成针对数据的基础转换。
3.图文 *** 作
1)开启kettle工具
将kettle4.1.0文件夹拷贝到本地路径,例如D盘根目录。
双击运行kettle文件夹下的spoon.bat文件,进入kettle主页面:
关闭Repository Connection窗口
2)创建transformation
主窗口左上角“文件”--》“新建”--》“转换”,点击保存到本地路径,例如保存到D:/etltest下,保存文件名为 EtlTestTrans,默认后缀为ktr.
3)创建Oracle连接
在transformation页面下,点击左边的“主对象树”,双击“DB连接”进行数据库连接配置。如图:
Connection name 自命名连接名称
Connection Type选择需要连接的数据库
Host name 数据库服务器的ip地址
DataBase name 数据库名称
Port Number 端口号
User name 用户名
Password 密码
填写内容如下:
填写完后,点击按钮“Test”.
如图上,表示连接成功。点击确定,然后点击保存数据库连接。
4)创建sqlServer连接
与创建Oracle连接大同小异,如图:
ODBC DSN Source name 数据源名称
这里我用的是ODBC连接,需要配置数据源:
控制面板--管理工具--数据源(ODBC)--系统DNS--添加--……
5)表输入
核心对象--输入--表输入,将表输入 拖到右边的主窗口,双击表输入如图:
自命名表输入名称,数据库连接下拉框选择etltest数据库(步骤3. 3)的oracle连接),
点击“获取SQL查询语句”,d出框:
双击你要导出数据的表,点击确定。
6)字段选择
核心对象--转换--字段选择,将字段选择 拖到右边的主窗口,
按住SHIFT键,用鼠标创建的表输入,拖动到字段选择上,则建立了两个环节之间的连接。
双击字段选择,在下图窗口中“选择和修改”和“元数据”tab页分别点击获取选择的字段按钮,然后确定。
7)表输出
与表输入大同小异。
@H_301_258@
4.遇到的问题
1)连接Oracle问题:注意Database name,是配置文件TNSnameS.ORA中数据库的配置名称。
2)连接sqlServer问题:用JDBC始终不成功,最后改用ODBC连接。
3)两库中表某字段类型不同:oracle中的blob类型--》sqlserver中的varbinary类型,最终改为Image类型。
总结以上是内存溢出为你收集整理的利用kettle工具 sqlserver2008导入oracle数据全部内容,希望文章能够帮你解决利用kettle工具 sqlserver2008导入oracle数据所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)