设为首页 收藏本站
查看: 1346|回复: 0

[经验分享] 大规模数据 从SQL SERVER导入到ORACLE方法

[复制链接]

尚未签到

发表于 2017-7-13 20:50:16 | 显示全部楼层 |阅读模式
  来源于:http://blog.csdn.net/iitkd/article/details/40394789
  来源:一个7G的SQL SERVER .bak文件要导入到Oracle中,经过实验,完成操作,先记录操作的过程,供类似的导入导出数据参考。
  实验环境:VMBox虚拟机,Window8.1专业版,SQL SERVER2012,ORACLE 11G,7G 的.bak备份文件
  简要过程:
  (1)首先配置环境,然后使用sql server2012导入备份文件,然后可以查看文件中数据库,表的结构。
表1.1 导入数据库,表

DSC0000.jpg

  (2)新建查询,使用xx命令将数据库中的cdsgus表导出到test.txt文本。使用xp_cmdshell 和bcp命令完成。
  exec xp_cmdshell 'bcp shifenzheng.dbo.cdsgus out c:\test.txt -c -T'
  提示:

  • bcp命令用法可以参考   http://www.cnblogs.com/qanholas/archive/2011/07/05/2098616.html


  • b.xp_cmdshell使用是可能出现问题,不存在或高级问题,可以使用下面的命令开启:



[sql] view plain copy

  • exec sp_configure 'show advanced options 1'  

  • go

  • reconfigure

  • go

  • exec sp_configure 'xp_cmdshell',1  

  • go
  如果仍然出现xp_cmdShell命令无法使用时,可以通过以下步骤开启命令:   
  选中对象资源管理器中的连接的服务器,右键-->方面-->弹出对话框,在下拉选项中选择”外围应用配置器“,设置XPCMDShellEnabled属性为true;再次尝试xp_cmdshell命令。
表1.2开启命令XPCMDShell-方面对话框

DSC0001.jpg

  运行命令,等待一段时间,完成数据库表的导出,生成test.txt文件,作为导入Oracle数据库的中间文件。
  其中test.txt中仅存有数据,没有表格的数据结构。
  (3)使用sqlldr命令和control.ctl控制文件导入Oracle

  • 首先在Oracle中建立一张表格,表格字段与sql server中的字段完全一样。
  • 构建control.tct文件,填写对应的内容。
  • 在cmd命令下,运行sqlldr scott/tiger@orcl control=control.txt命令即可。注意导入的txt,control.txt和当前CMD的工作目录在同一个地方,路径问题需要注意。
  详细Oracle导入txt文件用法详见:http://blog.csdn.net/programpoet/article/details/4516377
  备注:
  使用txt作为中间文件的好处就是,不用必须同时在一台电脑上安装sql server 和Oracle数据库,txt文件存放中间结果,可以不同电脑上进行数据的转移,降低数据转移对电脑的要求。
  本人就是在虚拟机上进行的数据转移:两个win8.1虚拟系统,分别安装sqlserver 和Oracle数据库,然后进行数据的导入和导出,降低了虚拟机对空间的要求,我的是7G的数据,第一次尝试时出现了虚拟机磁盘空间不够用的情况,安装数据库需要磁盘空间,导入数据需要磁盘空间,导出数据也要磁盘的空间。鉴于空间问题,数据库便分开在两个虚拟机系统上,txt作为中间传输的方式。
  还有就是sql server本身自带的导入Oracle的组件,使用时出现 了数据链接错误,说Oracle组件没有安装,不知道怎么做了,便采用了上述的方式,完成数据迁移。

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-393577-1-1.html 上篇帖子: SQL SERVER 数据库各版本功能对比 下篇帖子: SQL Server 2008 R2 链接 Oracle
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表