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

 

   一直听说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
    {
        
///  
        
///  导出数据库到Oralce
        
///  

         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());
        }

        
///  
        
///  导出一个表
        
///  

        
///   表名
        
///   里面的数据
         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 等等众多。。。

 

 

将权限管理、工作流管理做到我能力的极致,一个人只能做好那么很少的几件事情。

About

吉日嘎拉(蒙古语为吉祥如意),2000年毕业于黑龙江大学计算机系软件专业,目前定居杭州,典型的IT软件土鳖一个,外号“软件包工头”。

 

通用权限管理系统组件(GPM - General Permissions Manager)自2003年开始发布,目前是国内注册用户和免费盗版用户最多的权限管理系统,是各种信息管理系统开发中彻底的权限解决方案。本组件支持多种主流数据库(Oracle、sqlsever、db2、mysql),功能强大,使用方便,代码简洁,思路严谨,被广大支持者称为权限管理系统中的“走火入魔级权限管理系统”。

 

精心维护通用权限管理系统组件(GPM - General Permissions Manager)有8年多,3年的不断推广,20万行经典的业务逻辑积累,经过上万次的调试修正,经历了四百个付费客户,上百软件公司的实战开发。

11年以上开发经验,外企工作5年,上市公司3年,独立经营软件公司2年,主持研发部门管理工作4年以上。

将权限管理、工作流做到我能力的极致,一个人只能做好那么很少的几件事情。


QQ:252056973,Mail:[email protected]

访问者分布 把C#.NET程序移植到DB2上的经验浅谈(C#连接DB2可以用IBM.Data.DB2.dll)_第1张图片

通用权限管理模块的严谨设计定位、精心编码实现、不断维护推广、持续优化改进,主要是为了实现一个可以高度重复利用劳动成果的工具软件并×××给所需的人们,另想成为国人值得骄傲的知名软件功能模块。

可供国内管理类开发人员在日常工作中进行灵活二次开发利用的模块,开发管理类软件的必备工具之一,我们的目标就是让程序员早点儿回家休息。

淘宝店地址:http://jirigala.taobao.com