记一次SQL Server2005导入Oracle10G的折腾过程【供多种数据库导入导出数据的C#程序源码参考】

本文涉及的产品
RDS SQL Server Serverless,2-4RCU 50GB 3个月
推荐场景:
云数据库 RDS SQL Server,基础系列 2核4GB
简介:

 曾经很早的时候用 SQL Server2000 时就见过我们老大,用 SQL Server2000 的导入导出功能,把数据都导入到了 Oracle9 里去,所以我也对导入导出数据有充分的信心,绝对能做好。


  客户需要一个Oracle版本的通用权限管理系统组件的数据库,而且为此还支付了5000元的技术咨询费。最近一段时间Oracle用得不多,电脑里没也装Oracle,想来想去应该家里的移动硬盘里,有Oracle11G,就装了一个,装好后总感觉用户创建的不正确,折腾来折腾去,又卸载又重新装了一下,这个前后估计耗费了2-3个小时。

  但是想从 SQL Server2005 导入到Oracle11G时总是出现错误,折腾了1-2个小时也没能搞定,接着又尝试从 SQL Server2008 导入到 Oracle11G还是不行照样有错无法正常导入,这时候简直有些绝望了,唉连微软的工具都无法正常导入导出数据。


  这时候我就咨询群里的朋友,有一个做开发的朋友推荐用 Kettle ,这个数据库导入导出工具好不容易在网上下载了一个,无法正常运行,又下载了JDK什么的,接着还说缺这个文件缺哪个文件,然后朋友又发了那些缺的文件,但是程序还是无法正常运行,折腾这些,足足消耗了2个小时以上,家里的网络只有2M,下载的速度也不太快。

  所以用一些不熟悉的东西,有一定的风险,同时可能还需要很多学习成本。我电脑用的是win7 32位的,始终没明白为啥 Kettle 没能正常运行。


  有一个比较擅长开发Oralce的朋友又推荐我用sqldeveloper-3.0.03.45.zip,但是死活找不到相关下载,好不容易Oracle的下载里有一个,但是也无法下载,版本也过低,由于这个软件也比较庞大,客户也无法从网上很顺利的发过来,左找右找,又耗费了1-2个小时,顺便看看相关的文章,折腾了半死,结果没能突破,再次想用工具的想法被破灭了。


  有朋友推荐用微软的SQL Server Business Intelligence Development Studio 来折腾导入导出,结果折腾1-2个小时,还是无法正确导入导出表结构及数据,又是失败告终,真是折腾人啊。


  4次想用工具导入数据的尝试,均告失败后,真是有些绝望了,足足一天时间就被这么浪费掉了。只能硬这头皮自己上了,客户的问题总需要解决。

  实在是没办法那就自己动手导入吧,从 PowerDesigner 15 的模型里把数据库表结构都折腾好,导入到 Oracle11G 结果发现表名被区别大小写了,又把所有创建好的表都删除了,折腾了1个小时,又把 表重新建立一遍, 把SQL语句里的“符号全部替换掉了,才把表结构建立好了。

  实在忍无可忍了,自己写了程序写了1个小时不到,把导入导出的程序写了一遍,一执行,几分钟就搞定了,唉,早知道这个效果早就自己写个程序就好了,前后也就2-3个小时就可以了。


  好不容易导入 Oracle11G 成功后,客户无法正确导入我提供的数据文件,客户用的是  Oracle10G, 我又在电脑里装了一个 Oracle10G 的客户端,又把数据用 Oracle10G 导出一次,客户才正确导入了数据,这么一来回折腾又耗费了好几个小时。


  这期间程序的多数据库兼容性测试也耗费了几个小时调试,其实光把 SQL Server2005导入Oracle10G 的折腾过程,足足耗费了2天时间,人都有点儿累了,虽然嘴巴说说是很简单的事情,真的折腾起来真是不只是脑力活儿还更是体力活儿。



  程序代码的参考如下:

//--------------------------------------------------------------------

//  All Rights Reserved , Copyright (C) 2011 , Hairihan TECH, Ltd. 
// --------------------------------------------------------------------

using  System.Data;

namespace  DotNet.Example
{
using  DotNet.BaseManager;
using  DotNet.DbUtilities;

public class  ImportExportData
   {
/// <summary>
///  导出数据库到Oralce
/// </summary>
public void  Export()
       {
// this.ExportTable("Items_Area");
// this.ExportTable("Items_AuditStatus");
// this.ExportTable("Items_Degree");
// this.ExportTable("Items_Duty");
// this.ExportTable("Items_Education");
// this.ExportTable("Items_Express");
// this.ExportTable("Items_Links");
// this.ExportTable("Items_MembershipLevels");
// this.ExportTable("Items_Nationality");
// this.ExportTable("Items_NewsCategory");
// this.ExportTable("Items_OnSale");
// this.ExportTable("Items_OrganizeCategory");
// this.ExportTable("Items_Party");
// this.ExportTable("Items_Pattern");
// this.ExportTable("Items_PayCategory");
// this.ExportTable("Items_PostCategory");
// this.ExportTable("Items_RoleCategory");
// this.ExportTable("Items_SalaryItemCategory");
// this.ExportTable("Items_SendCategory");
// this.ExportTable("Items_Sex");
// this.ExportTable("Items_Title");
// this.ExportTable("Items_Units");
// this.ExportTable("Items_UserAuditStates");
// this.ExportTable("Items_Wed");
// this.ExportTable("Items_WorkCategory");
// this.ExportTable("Items_WorkFlowCategories");
// this.ExportTable("Items_WorkingProperty");
// this.ExportTable("Base_Businesscard");
// this.ExportTable("Base_Comment");
// this.ExportTable("Base_Contact");
// this.ExportTable("Base_ContactDetails");
// this.ExportTable("Base_Exception");
// this.ExportTable("Base_File");
// this.ExportTable("Base_Folder");
// this.ExportTable("Base_Items");
// this.ExportTable("Base_Log");
// this.ExportTable("Base_Message");
// this.ExportTable("Base_News");

// this.ExportTable("Base_Organize");
// this.ExportTable("Base_Module", " SELECT * FROM BASE_MODULE ORDER BY PARENTID, ID ");
// this.ExportTable("Base_PermissionItem");
// this.ExportTable("Base_Role");
// this.ExportTable("Base_Staff");

// this.ExportTable("Base_Parameter");
// this.ExportTable("Base_Project");
// this.ExportTable("Base_Permission");
// this.ExportTable("Base_PermissionScope");

this .ExportTable( " Base_Sequence " );

// this.ExportTable("Base_StaffOrganize");
// this.ExportTable("Base_TableColumns");
// this.ExportTable("Base_User");
// this.ExportTable("Base_UserAddress");
// this.ExportTable("Base_UserOrganize");
// this.ExportTable("Base_UserRole");
// this.ExportTable("Base_StaffOrganize");
// this.ExportTable("Base_WorkFlowActivity");
// this.ExportTable("Base_WorkFlowCurrent");
// this.ExportTable("Base_WorkFlowHistory");
// this.ExportTable("Base_WorkFlowProcess");

           System.Console.ReadLine();
       }

public void  ExportTable( string  tableName)
       {
           ExportTable(tableName, tableName);
       }

/// <summary>
///  导出一个表
/// </summary>
/// <param name="tableName"> 表名 </param>
/// <param name="table"> 里面的数据 </param>
public void  ExportTable( string  tableName,  string  table)
       {
//  这里是获取数据
           SqlHelper sqlHelper  = new  SqlHelper( " Data Source=localhost;Initial Catalog=UserCenterV32;Integrated Security=SSPI; " );
           sqlHelper.Open();
           DataTable dataTable 
= new  DataTable(tableName);
if  (tableName.Equals(table))
           {
               dataTable 
=  sqlHelper.Fill( " SELECT * FROM  " +  table);
           }
else
           {
               dataTable 
=  sqlHelper.Fill(table);
           }
           sqlHelper.Close();

//  这里是插入数据
           OracleHelper oracleHelper  = new  OracleHelper( " Data Source=ORACLE11;user=DBO_USERCENTERV32;password=DBO_USERCENTERV32; " );
           oracleHelper.Open();
           oracleHelper.BeginTransaction();
           SQLBuilder sqlBuilder 
= new  SQLBuilder(oracleHelper);
try
           {
//  清除表数据
               oracleHelper.ExecuteNonQuery( " TRUNCATE TABLE  " +  tableName);
//  创建配套的序列
//  oracleHelper.ExecuteNonQuery("create sequence SEQ_" + tableName + " minvalue 1 maxvalue 999999999999999999999999 start with 1 increment by 1 cache 20");

int  r  = 0 ;
for  (r  = 0 ; r  <  dataTable.Rows.Count; r ++ )
               {
                   sqlBuilder.BeginInsert(tableName);
for  ( int  i  = 0 ; i  <  dataTable.Columns.Count; i ++ )
                   {
                       sqlBuilder.SetValue(dataTable.Columns[i].ColumnName, dataTable.Rows[r][dataTable.Columns[i].ColumnName]);
                   }
                   sqlBuilder.EndInsert();
                   System.Console.WriteLine(
" 表  " +  tableName  + "  已插入第  " +  r.ToString()  + "  行 " );
               }
               System.Console.WriteLine(
"  - - 表  " +  tableName  + "  共插入  " +  r.ToString()  + "  行 " );
               oracleHelper.CommitTransaction();
           }
catch  (System.Exception exception)
           {
               oracleHelper.RollbackTransaction();
               System.Console.WriteLine(tableName 
+ "  --  " +  exception.Message);
           }
finally
           {
               oracleHelper.Close();
           }
       }
   }

}





本文转自 jirigala 51CTO博客,原文链接: http://blog.51cto.com/2347979/1200711,如需转载请自行联系原作者
相关实践学习
使用SQL语句管理索引
本次实验主要介绍如何在RDS-SQLServer数据库中,使用SQL语句管理索引。
SQL Server on Linux入门教程
SQL Server数据库一直只提供Windows下的版本。2016年微软宣布推出可运行在Linux系统下的SQL Server数据库,该版本目前还是早期预览版本。本课程主要介绍SQLServer On Linux的基本知识。 相关的阿里云产品:云数据库RDS&nbsp;SQL Server版 RDS SQL Server不仅拥有高可用架构和任意时间点的数据恢复功能,强力支撑各种企业应用,同时也包含了微软的License费用,减少额外支出。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/sqlserver
相关文章
|
22天前
|
SQL 开发框架 .NET
ASP.NET连接SQL数据库:详细步骤与最佳实践指南ali01n.xinmi1009fan.com
随着Web开发技术的不断进步,ASP.NET已成为一种非常流行的Web应用程序开发框架。在ASP.NET项目中,我们经常需要与数据库进行交互,特别是SQL数据库。本文将详细介绍如何在ASP.NET项目中连接SQL数据库,并提供最佳实践指南以确保开发过程的稳定性和效率。一、准备工作在开始之前,请确保您
104 3
|
4天前
|
SQL 数据采集 监控
局域网监控电脑屏幕软件:PL/SQL 实现的数据库关联监控
在当今网络环境中,基于PL/SQL的局域网监控系统对于企业和机构的信息安全至关重要。该系统包括屏幕数据采集、数据处理与分析、数据库关联与存储三个核心模块,能够提供全面而准确的监控信息,帮助管理者有效监督局域网内的电脑使用情况。
11 2
|
8天前
|
存储 数据挖掘 数据库
数据库数据恢复—SQLserver数据库ndf文件大小变为0KB的数据恢复案例
一个运行在存储上的SQLServer数据库,有1000多个文件,大小几十TB。数据库每10天生成一个NDF文件,每个NDF几百GB大小。数据库包含两个LDF文件。 存储损坏,数据库不可用。管理员试图恢复数据库,发现有数个ndf文件大小变为0KB。 虽然NDF文件大小变为0KB,但是NDF文件在磁盘上还可能存在。可以尝试通过扫描&拼接数据库碎片来恢复NDF文件,然后修复数据库。
|
24天前
|
SQL 关系型数据库 MySQL
Go语言项目高效对接SQL数据库:实践技巧与方法
在Go语言项目中,与SQL数据库进行对接是一项基础且重要的任务
40 11
|
16天前
|
SQL 移动开发 Oracle
SQL语句实现查询连续六天数据的方法与技巧
在数据库查询中,有时需要筛选出符合特定时间连续性条件的数据记录
|
23天前
|
SQL 监控 数据库
慢SQL对数据库写入性能的影响及优化技巧
在数据库管理系统中,慢SQL(即执行缓慢的SQL语句)不仅会影响查询性能,还可能对数据库的写入性能产生显著的不利影响
|
23天前
|
SQL 数据库 数据库管理
数据库SQL函数应用技巧与方法
在数据库管理中,SQL函数是处理和分析数据的强大工具
|
24天前
|
SQL 监控 Oracle
Oracle SQL性能优化全面指南
在数据库管理领域,Oracle SQL性能优化是确保数据库高效运行和数据查询速度的关键
|
23天前
|
SQL 存储 关系型数据库
添加数据到数据库的SQL语句详解与实践技巧
在数据库管理中,添加数据是一个基本操作,它涉及到向表中插入新的记录
|
24天前
|
SQL 关系型数据库 Shell
SQL整库导出语录及其实用技巧与方法
在数据库管理和备份恢复过程中,整库导出是一项至关重要的任务