把C#.NET程序移植到DB2上的经验浅谈(C#连接DB2可以用IBM.Data.DB2.dll)

简介:

  一直听说DB2是个很牛叉的数据库,但是从知道有这么一个数据库到真正有机会用还是经过了漫长的岁月,到了今年的7、8月份才有机会用这个数据库。最近在北京做某银行的现金管理系统,银行要求要用DB2数据库,没办法把所有的程序都在DB2上进行了一次改进优化。


  废话不多说,直接分享经验。

  01:寻找DB2的安装盘折腾了1-2周,因为不太擅长干这个,DB2有好几个版本,会分32位、64位的不同的安装版本,开发阶段当然是运行在Windows平台下,只是真实部署时会在其他非Windows系统下而已,第一个安装盘始终安装失败,后来同事又发了一个版本,一安装就成功了,安装过程非常简单,基本上只要设置用户名、密码就可以了,只要找到合适的安装盘会非常顺利了,安装程序不是很大只有几百兆1G都不到,安装过程完毕运行程序会出现一个错误,在Windows里设置一下权限就可以正常使用了、Google一下就可以解决了。


  02:DB2里如何执行SQL语句摸索了2天才会,因为没人教,身边也没人会这个,手头也没任何DB2的参考书,就靠自己瞎摸索,终于知道了如何执行SQL语句了,过了这个关后,基本上想干啥都会顺利一些了,下面就是DB2的管理工具。

2011080401.png


  03:DB2的Windows版本的用户可以与Windows的系统用户集成在一起,用起来很方便,管理起来也灵活了。


  04:DB2里2个字符相加,跟Oralce一样,都需要用 “||” 符号,参数化也用 @符号,这些没什么大区别,也跟Oralce类似有 Dual 等特殊的表。


  05:DB2里,又有子增量,又有序列,这方面比sqlsever好用多了,毕竟Oracle有序列,没字增量,但是DB2很爽,字增量、序列的功能都有,主键可以灵活采用采用这2个方式之一,这样效率也高一些,也会减少一些并发带来的麻烦,省事一些。


  06:DB2也有分页的语句与Oralce类似,查几下资料就可了。


  07:DB2里也可以建立分区等等,这个跟Oralce很相似、虽然DB2的管理工具也不是很漂亮,但是用起来还算舒服,比Oralce自带的管理工具强很多,当然说管理工具最好用的还是sqlserver的,复制粘贴、批量复制粘贴等非常友善,这方面DB2、Oralce是差距甚远、他们没考虑菜鸟级大众用户,只考虑了专家。


  08:那C#访问DB2用什么类、这个DLL哪里下载?这个折腾了不少,到IBM网站上注册了用户,才下载到这个DLL,虽然是VS2005版本的,但是也可以安装,然后直接找到相应的DLL,复制过来,引用到自己的项目里就可以了。我采用了IBM.Data.DB2.dll。


  09:接下来就是解决 数据库连接串的问题,没几下就测试成功了数据库连接串,参考数据库链接串如下:

< add key = " UserCenterDbConnection "  value = " Database=JIRI_UC;UserID=administrator;Password=pAssw0rd;Server=WIN-3T3M2TTDAFK; " />
< add key = " BusinessDbConnection "  value = " Database=JIRI_DB;UserID=administrator;Password=pAssw0rd;Server=WIN-3T3M2TTDAFK; " />


 10:接下来就是导数据的工作了,以前花费几天写了一个将数据导入到Oralce的工具,这次稍微修改几下花费了半个小时就改进为又支持导入Oralce、也支持导入DB2等任何数据库的导入导出工具,代码贴出来给大家分享一下,代码总共没几行、但是非常实用。

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

using  System.Data;

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

public class  ImportExportData1
   {
/// <summary>
///  导出数据库到Oralce
/// </summary>
public void  Export()
       {

// this.ExportTable("ItemDetails");
// this.ExportTable("Items_Condition");

// this.ExportTable("Items_Currency");
// this.ExportTable("Items_E_Signature");
// this.ExportTable("Items_RoleCategory");
// this.ExportTable("Items_SecurityLevel");
// this.ExportTable("Items_TablePermissionScope");

// this.ExportTable("Base_Comment");
// 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_Organize");
this .ExportTable( " Base_Module " );
// this.ExportTable("Base_PermissionItem");


// this.ExportTable("Base_Role");


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

// this.ExportTable("Base_Sequence");
//  this.ExportTable("Base_TableColumns");
//  this.ExportTable("Base_User");
//  this.ExportTable("Base_UserAddress");
//  this.ExportTable("Base_UserOrganize");
//  this.ExportTable("Base_UserRole");


// 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.ToUpper(), tableName.ToUpper());
       }

/// <summary>
///  导出一个表
/// </summary>
/// <param name="tableName"> 表名 </param>
/// <param name="table"> 里面的数据 </param>
public void  ExportTable( string  tableName,  string  table)
       {
//  这里是获取目标数据表的方法
           IDbHelper sourceDB  = new  SqlHelper( " Data Source=192.168.0.121;Initial Catalog=UserCenterJMCB;User Id = sa ; Password = Password@1; " );
           sourceDB.Open();
           DataTable dataTable 
= new  DataTable(tableName);
if  (tableName.Equals(table))
           {
               dataTable 
=  sourceDB.Fill( " SELECT * FROM  " +  table);
           }
else
           {
               dataTable 
=  sourceDB.Fill(table);
           }
           sourceDB.Close();

//  这里是目标表的数据插入处理
//  IDbHelper targetDB = new OracleHelper("Data Source=KANGFU;user=usercenter;password=usercenter;");
//  IDbHelper targetDB = new DB2Helper("Database=JMCB_UC;UserID=JoinMoreCash;Password=P@ssw0rd;Server=WIN-3T3M2TTDAFK;");
           IDbHelper targetDB  = new  DB2Helper( " Database=JMCB_UC;UserID=administrator;Password=p@ssw0rd2077;Server=WIN-3T3M2TTDAFK; " );
           targetDB.Open();
//  targetDB.BeginTransaction();
           SQLBuilder sqlBuilder  = new  SQLBuilder(targetDB);
try
           {
//  清除表数据
//  targetDB.ExecuteNonQuery(" TRUNCATE TABLE " + tableName);
               targetDB.ExecuteNonQuery( "  DELETE FROM  " +  tableName);
//  创建配套的序列
//  targetDB.ExecuteNonQuery("create sequence SEQ_" + tableName.ToUpper() + " as bigint start with 1000000 increment by 1 minvalue 10000 maxvalue 99999999999999999 cycle cache 20 order");
//  targetDB.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()  + "  行 " );
               targetDB.CommitTransaction();
           }
catch  (System.Exception exception)
           {
//  targetDB.RollbackTransaction();
               System.Console.WriteLine(tableName  + "  --  " +  exception.Message);
           }
finally
           {
               targetDB.Close();
           }
       }
   }
}


 11:为了相对系统的了解一下DB2数据库,狠下心30多元买了一本,翻了一天心里有感觉了,接着遇到什么问题Google一下基本上就可以解决了。


  前后折腾了半个多月,终于把C#.NET通用权限管理组件全部在DB2上调试了一遍,从从来没摸过DB2到把数据库都折腾好,很多事情说起来简单,但是真正做好,做细节就会耗费很多时间,2周多时间就这么一眨眼就过去了。其实这2周的成本大概是上万(杭州来回北京的路费 + 住酒店的费用 + 工资成本 + 测试成本),还有好几个人给测试确认功能是否正确。


  软件是否值钱?想把一个软件卖10000是很难的,很多人不能接受,但是等有需要时花费20000也搞不定就可以充分体验到软件贵如金,还好这些都由客户买单否则自己还真没实力乱折腾。这还不是开发通用权限管理系统的成本,只是实现一个DB2数据库上的兼容性就需要有这些成本才能实现好。

  若真有又便宜质量又好的软件源码,购买远比自己开发强,自己写远没有分析理解别人的代码上改进几下见效快,何必跟自己过不去呢,浪费那么多生命重复建设干啥,若我工作上遇到的难题,都可以别人能帮忙解决的话会全部购买了完事了,该休息休息了。


  C#连接DB2可以用IBM.Data.DB2.dll, 有需要这个类库的,加我QQ:252056973 索取。以上是肤浅的总结、有不足之处请指正、欢迎大家留言发表见解。

通用权限管理系统组件源码现在支持 Access, mysql, sqlserver, Oracle, db2, SqLite 等等众多。。。




本文转自 jirigala 51CTO博客,原文链接:http://blog.51cto.com/2347979/1197375,如需转载请自行联系原作者
相关文章
|
9天前
|
数据可视化 网络协议 C#
C#/.NET/.NET Core优秀项目和框架2024年3月简报
公众号每月定期推广和分享的C#/.NET/.NET Core优秀项目和框架(每周至少会推荐两个优秀的项目和框架当然节假日除外),公众号推文中有项目和框架的介绍、功能特点、使用方式以及部分功能截图等(打不开或者打开GitHub很慢的同学可以优先查看公众号推文,文末一定会附带项目和框架源码地址)。注意:排名不分先后,都是十分优秀的开源项目和框架,每周定期更新分享(欢迎关注公众号:追逐时光者,第一时间获取每周精选分享资讯🔔)。
|
1月前
|
SQL 数据库 C#
C# .NET面试系列十一:数据库SQL查询(附建表语句)
#### 第1题 用一条 SQL 语句 查询出每门课都大于80 分的学生姓名 建表语句: ```sql create table tableA ( name varchar(10), kecheng varchar(10), fenshu int(11) ) DEFAULT CHARSET = 'utf8'; ``` 插入数据 ```sql insert into tableA values ('张三', '语文', 81); insert into tableA values ('张三', '数学', 75); insert into tableA values ('李四',
61 2
C# .NET面试系列十一:数据库SQL查询(附建表语句)
|
1月前
|
开发框架 算法 搜索推荐
C# .NET面试系列九:常见的算法
#### 1. 求质数 ```c# // 判断一个数是否为质数的方法 public static bool IsPrime(int number) { if (number < 2) { return false; } for (int i = 2; i <= Math.Sqrt(number); i++) { if (number % i == 0) { return false; } } return true; } class Progr
58 1
|
1月前
|
并行计算 安全 Java
C# .NET面试系列四:多线程
<h2>多线程 #### 1. 根据线程安全的相关知识,分析以下代码,当调用 test 方法时 i > 10 时是否会引起死锁? 并简要说明理由。 ```c# public void test(int i) { lock(this) { if (i > 10) { i--; test(i); } } } ``` 在给定的代码中,不会发生死锁。死锁通常是由于两个或多个线程互相等待对方释放锁而无法继续执行的情况。在这个代码中,只有一个线程持有锁,且没有其他线程参与,因此不
101 3
|
3月前
|
Linux C# 开发工具
C#开源的一款友好的.NET SDK管理器
C#开源的一款友好的.NET SDK管理器
|
2天前
|
开发框架 前端开发 JavaScript
采用C#.Net +JavaScript 开发的云LIS系统源码 二级医院应用案例有演示
技术架构:Asp.NET CORE 3.1 MVC + SQLserver + Redis等 开发语言:C# 6.0、JavaScript 前端框架:JQuery、EasyUI、Bootstrap 后端框架:MVC、SQLSugar等 数 据 库:SQLserver 2012
|
28天前
|
Java C# 开发工具
第一个C#程序
第一个C#程序
12 0
|
1月前
|
数据采集 存储 C#
抓取Instagram数据:Fizzler库带您进入C#程序的世界
在当今数字化的世界中,数据是无价之宝。社交媒体平台如Instagram成为了用户分享照片、视频和故事的热门场所。作为开发人员,我们可以利用爬虫技术来抓取这些平台上的数据,进行分析、挖掘和应用。本文将介绍如何使用C#编写一个简单的Instagram爬虫程序,使用Fizzler库来解析HTML页面,同时利用代理IP技术提高采集效率。
抓取Instagram数据:Fizzler库带您进入C#程序的世界
|
1月前
|
SQL 存储 关系型数据库
C# .NET面试系列十:数据库概念知识
#### 1. 为什么要一定要设置主键? 设置主键是数据库设计中的一个重要概念,有几个主要原因: 1、唯一性 ```c# 主键必须保证表中的每一行都有唯一的标识。这样可以避免数据冗余和不一致性。如果没有主键或者主键不唯一,就可能出现数据混乱或错误。 ``` 2、查询性能 ```c# 数据库系统通常会使用主键来加速数据检索。主键通常会被索引,这样可以更快速地找到特定行的数据,提高查询效率。 ``` 3、关联性 ```c# 主键常常用于建立表与表之间的关系。在关系数据库中,一个表的主键通常与其他表中的外键建立关联,这种关系对于数据的一致性和完整性非常重要。 ``` 4、数据完
131 1
C# .NET面试系列十:数据库概念知识
|
1月前
|
XML 开发框架 .NET
C# .NET面试系列八:ADO.NET、XML、HTTP、AJAX、WebService
## 第二部分:ADO.NET、XML、HTTP、AJAX、WebService #### 1. .NET 和 C# 有什么区别? .NET(通用语言运行时): ```c# 定义:.NET 是一个软件开发框架,提供了一个通用的运行时环境,用于在不同的编程语言中执行代码。 作用:它为多语言支持提供了一个统一的平台,允许不同的语言共享类库和其他资源。.NET 包括 Common Language Runtime (CLR)、基础类库(BCL)和其他工具。 ``` C#(C Sharp): ```c# 定义: C# 是一种由微软设计的面向对象的编程语言,专门为.NET 平台开发而创建。 作
173 2