当前位置: 首页 > news >正文

临安市建设局门户网站/seo网络贸易网站推广

临安市建设局门户网站,seo网络贸易网站推广,互联网10大厂,公司软件网站开发怎么入账一直听说DB2是个很牛叉的数据库,但是从知道有这么一个数据库到真正有机会用还是经过了漫长的岁月,到了今年的7、8月份才有机会用这个数据库。最近在北京做某银行的现金管理系统,银行要求要用DB2数据库,没办法把所有的程序都在DB2上…

  一直听说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;

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 等等众多。。。




本文转自 jirigala 51CTO博客,原文链接:http://blog.51cto.com/2347979/1197375,如需转载请自行联系原作者
http://www.jmfq.cn/news/4804849.html

相关文章:

  • 除了做视频网站还能做什么网站/qq群推广引流免费网站
  • 网站做百度地图定位/如何去推广一个app
  • 百度下拉框推广网站/中文搜索引擎大全
  • 网站建设要域名和什么/设计公司网站设计
  • 链家网的网站开发费用大概多少钱/宣传推广的十种方式
  • 万网网站建设步骤/优云优客百度推广效果怎么样
  • 平顶山市做网站/班级优化大师功能介绍
  • 做电影网站失败了/网站推广服务报价表
  • 大沥网站建设制作/济南网站建设老威
  • 临沂市建设局兰山区网站/全网推广平台有哪些
  • 河北辛集住房和城乡建设厅网站/百度一下你就知道了
  • 吃的网站要怎么做/电商平台排行榜前十名
  • wordpress经验/广州网站优化
  • 专门做旅游攻略的网站有哪些/公众号seo排名优化
  • 做软件贵还是做网站贵/google关键词挖掘工具
  • 公司做网站 微信平台/百度爱采购推广平台
  • 自己做网站要不要钱/广州推广服务
  • 动态网站开发代码/百度如何搜索关键词
  • 网站的ftp怎么登陆/湖南seo快速排名
  • 广西网站建设/品牌宣传文案范文
  • 找人建设一个网站多少钱/新东方培训机构官网
  • 上海招聘网站建设/搜索引擎关键词怎么优化
  • 宝安做网站公司/邢台网站公司
  • 济南 域名注册 网站建设/百度登陆
  • 网站空间pdf下载不了/手机优化器
  • 网站外链坏处/seo的培训课程
  • 英文网站设计哪里好/建立网站
  • 免费企业网站怎么做/湖南网站设计外包费用
  • 北京模板建站哪家好/地推项目发布平台
  • 从信息化建设办公室网站/深圳网络营销推广专员