实现DB2功能的C#数据库编程实例

开发 后端
在Visual Studio.NET Beta 1版本中访问IBM DB2等非SQL Server数据库通常是使用ADO.NET的ODBC方法,而在Beta 2中则改用OLE DB方式存取数据库。本C#数据库编程实例将介绍如何实现。

在Visual Studio.NET Beta 1版本中访问IBM DB2等非SQL Server数据库通常是使用ADO.NET的ODBC方法,而在Beta 2中则改用OLE DB方式存取数据库。

Beta1中连接字符串主要需声明数据库的ODBC的DNS名字,但Beta 2中的OLE DB连接的字符串就较复杂了,使用的类也不相同。由于DB2等数据库在大型机等应用中使用非常广泛,.NET自然会全力支持此类编程开发,为此,下文将逐步阐述OLE DB的DB2开发。

C#数据库编程实例之OLE DB for DB2驱动

首先,Visual Studio.NET和Windows 2000 Server中并未直接提供DB2的OLE DB驱动,因此需下载Microsoft Host Integration Server 2000软件,该软件包中含OLE DB Provider and ODBC driver for DB2,需下载Server端软件包,并在安装时选择安装Data Integration,安装完成后就可使用其OLE DB的DB2驱动了。

C#数据库编程实例之设置数据库连接

首先,我们需配置好DB2的客户端设置,打开视图选单项中的服务器资源管理器,在其数据连接中新增一个连接,指定程序选项时选择Microsoft OLE DB Provider for DB2,下一步连接选项中,填写如下信息:

Data Source: QCDB(请酌情修改)

Network:TCP/IP

IP Address:数据库服务器地址

Network Port:DB2服务端口

Username:数据库访问权限的用户名

Password:该用户口令

Database initial Catalog:QCDB

Package collection:QCDB

default schema:Userid

下一步高级选项中选各自国家语言对应的code page及CCSID,最后按确认键完成创建连接。

假设QCDB这个DB2数据库中有一名为address的新数据表,其包含四个字段:name、email、age和address,我们可用服务器资源管理器打开上述连接及该数据表,可输入数条中文记录,确定中文字符能否正常显示。

C#数据库编程实例之为项目增加数据库连接

用Visual Studio新建一个ASP.NET项目,激活服务器资源管理器的上述连接,用鼠标将该连接拖至新建的Web Form上,则OLE DB需要的连接字符参数全部自动写入Web Form程序中,上述连接生成的语句如下:

  1. this.oleDbConnection1.ConnectionString 
  2. = @Provider=DB2OLEDB;  
  3. Cache Authentication=False;  
  4. Integrated Security=;  
  5. Password=freebsd9;  
  6. Persist Security Info=True;  
  7. User ID=userid;Initial Catalog=qcdb;  
  8. Data Source=qcdb;Mode=ReadWrite;  
  9. Extended Properties=;  
  10. APPC Remote LU Alias=;  
  11. APPC Local LU Alias=;  
  12. APPC Mode Name=QPCSUPP;  
  13. Network Transport Library=TCPIP;  
  14. Host CCSID=37;PC Code Page=1282;  
  15. Network Address=172.23.169.1;  
  16. Network Port=4444;Package Collection=qcdb;  
  17. Default Schema=userid;Alternate TP Name=;  
  18. Process Binary as Character=False;  
  19. Units of Work=RUW 

用服务器资源管理器工具生成连接可避免错写各种参数,从而可快速地实现数据库连接。

Web Form显示数据库数据

为Web Form新增一个OleDbDataAdapter类的对象oleDbDataAdapter1,为其选择数据连接时选上面建立的连接如:qcdb.qcdb.userid,选择使用SQL语句,生成SQL语句如:Select ?from address,最后提示完成。再为Web Form新增一个DataSet并命名为dataSet1用来放查询得到的数据。新增一个显示数据用的DataGrid命名为DataGird1,最后在Web Form的程序段中的Page_Init部分中增加如下代码:

  1. oleDbConnection1.Open();  
  2. //打开数据库连接  
  3. oleDbDataAdapter1.Fill(dataSet1,Address);  
  4. //将得来的数据填入dataSet  
  5. DataGrid1.DataBind();  
  6. //绑定数据  
  7. oleDbConnection1.Close();  
  8. //关闭连接 

编译运行后,可见address表中内容被显示于Web Form的DataBrid中。OleDbConnection1等属性设置都在生成的Web Form设计代码中。

C#数据库编程实例之增加数据库数据

在Web Form上新增对应字段数量个数的TextBox,及一个button,为该按键增加Click响应事件代码如下:

  1. this.oleDbInsertCommand1.CommandText 
  2. INSERT INTO ADDRESS(NAME, EMAIL, AGE, ADDRESS)  
  3. VALUES (+TextBox1.Text+,+TextBox2.Text+,  
  4. +TextBox3.Text+,+TextBox4.Text+);  
  5. oleDbInsertCommand1.Connection.Open();  
  6. //打开连接  
  7. oleDbInsertCommand1.ExecuteNonQuery();  
  8. //执行该SQL语句  
  9. oleDbInsertCommand1.Connection.Close();  
  10. //关闭连接 

实际编程中,我们需注意SQL语句的单引号问题以及数字和字符串处理问题。

删除数据库数据

在Web Form上新增一个TextBox5及一个按键,要执行删除时,在TextBox5中填入要删除记录的name字段的值,然后按该按键执行删除。该按键代码如下:

  1. System.Data.OleDb.OleDbCommand oleDeleteCommand1  
  2. new System.Data.OleDb.OleDbCommand();  
  3. this.oleDbDataAdapter1.DeleteCommand 
  4. oleDeleteCommand1;  
  5. //声明为oleDb命令  
  6. oleDeleteCommand1.CommandText 
  7. =DELETE FROM ADDRESS WHERE NAME=+TextBox5.Text+;  
  8. oleDeleteCommand1.Connection 
  9. this.oleDbConnection1;  
  10. //指明连接  
  11. oleDeleteCommand1.Connection.Open();  
  12. //打开连接  
  13. oleDeleteCommand1.ExecuteNonQuery();  
  14. //执行SQL语句  
  15. oleDeleteCommand1.Connection.Close();  
  16. //关闭连接 

对于增加、更新和删除操作后的DataGrid刷新,可执行类似的Select SQL语句即可。

上述代码可供各种非SQL Server数据库编程参考和使用,微软为此提供了如OLE DB Provider for Oracle、AS/400和VSAM等众多驱动,OLE DB方式确实提供了较ODBC方式更为广泛的数据存取范围,如可存取Access库中的数据、邮件系统中的数据、Web上的文本及图形、目录服务等等,符合ODBC标准的数据源就是符合OLE DB标准的数据存储的子集,而且OLE DB的API是符合COM标准和基于对象的API,这些都是较原ODBC方式有大幅改进,从而为综合的数据集成处理提供了更广泛的支持。

通过以上讲解,笔者希望使读者初步了解在Visual Studio.NET中,以DB2为后台数据库时应用系统的开发步骤,也希望读者举一反三,领会思想和方法,以便更好地应用到自己的系统开发中。

上述程序在中文Windows 2000 Server、IBM DB2和Visual Studio.NET Beta 2环境中编译并正常运行。

【编辑推荐】

  1. C#记忆功能的地址栏控件
  2. 描述C#调用外部进程
  3. C#语言操纵数据库事务
  4. 概述C#语言异常处理
  5. 简单介绍C#数组和函数
责任编辑:彭凡 来源: 比特网
相关推荐

2011-03-03 09:45:25

DB2数据库Visual C#

2010-11-03 16:32:10

DB2创建数据库

2009-08-25 17:20:57

C#实现OLE DB的

2010-07-30 09:22:54

DB2实现

2011-03-25 14:53:39

DB2数据库Oracle

2010-08-31 14:24:25

DB2联合数据库

2010-08-17 16:24:32

IBM DB2数据库

2011-03-11 16:02:03

DB2数据库安装

2010-08-04 11:18:09

2010-07-23 08:42:00

TOLLSDBDB2

2010-08-25 10:50:48

DB2数据库

2010-09-01 13:38:41

DB2数据复制

2010-08-16 13:45:27

安装DB2数据库

2010-11-01 13:45:16

DB2数据库的优势

2010-08-31 17:34:46

DB2

2010-11-01 11:30:41

DB2数据库权限

2010-11-03 16:21:18

DB2数据库授权

2010-09-30 11:49:21

DB2数据库权限

2010-08-26 16:15:25

DB2数据库管理

2010-08-18 15:31:30

DB2数据库恢复
点赞
收藏

51CTO技术栈公众号