感谢博客园不再封杀,差点儿搬家的念头都产生了,博客园还是有大胸怀,继续留在博客园写口水文应该没错,娱乐自己、娱乐大家,给枯燥的编程生活增加一点儿笑料,也给大家充当个开心果,让大家高兴一下下、轻松一下下,工作累了,看看吉日的文章心情就会好很多了,因为吉日技术太菜了还喜欢写文章分享更喜欢上首页不说文章内容又全是广告、嘿嘿。

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

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

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

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

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;

publicclass ImportExportData1
   {
///<summary>
/// 导出数据库到Oralce
///</summary>
publicvoid 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();
       }

publicvoid ExportTable(string tableName)
       {
           ExportTable(tableName.ToUpper(), tableName.ToUpper());
       }

///<summary>
/// 导出一个表
///</summary>
///<param name="tableName">表名</param>
///<param name="table">里面的数据</param>
publicvoid 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 等等众多。。。

转载于:https://blog.51cto.com/2347979/1197375

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

  1. 将c程序移植到linux,各位大侠:我把原来在linux运行的c程序移植到HPUNIX上出现了错误...

    各位大侠:我把原来在linux运行的c程序移植到HPUNIX上出现了错误 (2012-04-11 00:43:47) 标签: linux c程序 杂谈 各位大侠:我把原来在linux运行的c程序移植到 ...

  2. java 复杂网络分析_基于复杂网络的Java程序分析工具设计与实现思路浅谈

    基于复杂网络的Java程序分析工具设计与 实现思路浅谈 摘要:近年来,随着科学技术的进步,计算机技术发展速度的加快,使得软件价值也逐步提高,不管是软件系统的应用领域,还是其规模均获得了相应的扩大,且软 ...

  3. 制衣毛织企业上ERP系统浅谈之:我要的是什么?

    制衣毛织企业上ERP系统浅谈之:我要的是什么? 做服装行业的ERP实施工作也快十年了,截止到今天为止,还是发现有很多的企业对于自己要的是什么不是十分清晰. 如果目标不明确就去上ERP,终究会事倍功半. ...

  4. c程序语言的常量变量和标识符,浅谈C语言中的常量与变量.pdf

    课程教育研究 CourseEducationResearch 2014年4月 上旬刊 教学.信息 浅谈C语言中的常量与变量 刘 星 (青 岛工学院商学院 山东 青岛 266300) [摘要]在任何一种 ...

  5. 计算机网络在教学上的应用,浅谈计算机网络在教学中的应用.doc

    浅谈计算机网络在教学中的应用 精品论文 参考文献 浅谈计算机网络在教学中的应用 冯 娟 湖北省咸丰县忠堡镇民族中学 445600 随着现代科学技术的飞速发展,现代信息技术以其生动形象.图像清晰.色彩艳 ...

  6. 计算机在科学研究上的意义,浅谈自然辩证法对计算机科学研究的意义

    学计算机的人,懂一点自然辩证法非常好 姓名:司嘉伟 学号:1100379181 浅谈自然辩证法对计算机科学研究 的意义 [摘要]计算机科学是自然科学的一个分支.如同其他自然科学一样,我们要对材料进行观 ...

  7. Linux程序移植到Android上

    序言: 由于本人还是比较偏重于先说明原理在说明实际操作步骤,要知其然更要知其所以然,如下图所示: 传统的linux系统中的程序基本都依赖于glibc(至于什么是glibc可以百度去),而右边AOSP( ...

  8. 1_机智云程序移植到HT32F52352上

    一.WiFi模块烧录机智云的固件 WiFi模块用的是正点原子的ATK-ESP-01,Flash的大小是8Mbit,机智云对应的固件可在此下载. 如点击资源下载没有反应,则在资源下载处右键,选择这三个中 ...

  9. IIS 之 未能加载文件或程序集“IBM.Data.DB2”或它的某一个依赖项。试图加载格式不正确的程序。...

    问题如下图所示: 原因分析:操作系统是64位的,但发布的程序引用了一些32位的ddl,所以出现了兼容性的问题. 解决方案:IIS → 应用程序池 → 对应的程序池 → 高级设置 → 启用32位应用程序 ...

最新文章

  1. python输出word内容_Django输出word文件(.doc),只在内容中显示原始html
  2. 【CV】基于python和OpenCV构建智能停车系统
  3. Ping命令及其协议
  4. 分享一个HTML5画布实现的超酷文字弹跳球效果
  5. 获取本地IP和mac等信息
  6. 精美UI版iApp对接hybbs论坛功能APP源码
  7. python错误代码提示手册_腾讯大佬整理了 Python 所有内置异常,Python高手必备的排错手册...
  8. 十八、泛型 l 注解 l Servlet3.0 l 动态代理 l 类加载器基础加强
  9. 书单丨5本经典著作描绘C++学习路线图
  10. 超详细mac新手教程-Mac界面篇
  11. 两年经验拿到蚂蚁/头条 Offer(面经分享)
  12. 将GitHub源代码打包成jar包
  13. web应用防火墙和传统防火墙的区别。
  14. 二进制、八进制、十六进制的写法
  15. ambari全攻略流程,编译ambari(三)
  16. 科技型中小企业研发费用加计扣除问题解答
  17. java为文本框添加背景颜色,文本框添加背景图片,文本框背景图片,文本框添加水印[Java...
  18. 相机响应曲线、ISO详解
  19. The Shawshank Redemption-11
  20. 车速与档位匹配关系_汽车档位与速度的匹配,速度与档位匹配的标准

热门文章

  1. scala 方法、函数定义小结
  2. BZOJ3019 : [Balkan2012]handsome
  3. RHEL5U8配置Centos yum源
  4. Python中如何把一个UTC时间转换为本地时间
  5. 疯狂ios讲义疯狂连载之实现游戏逻辑(2)
  6. 【成长点滴】对SMART原则的一些粗浅理解
  7. “玩转课堂”基本构想
  8. 联想(Lenovo)小新310经典版进bios方法
  9. C#中二进制和流之间的各种相互转换
  10. ThinkPHP讲解(十二)——文本编辑器和ajax传址