一直听说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; 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 等等众多。。。