在Visual Studio.NET Beta 1版本中访问IBM DB2等非SQL Serve r数据库通常是使用ADO.NET的ODBC方法,而在Beta 2中则改用OLE DB方式存取数据库。
B eta1中连接字符串主要需声明数据库的ODBC的DNS名字, 但Beta 2中的OLE DB连接的字符串就较复杂了,使用的 类也不相同。由于DB2等数据库在大型机等应用中使用非常广泛, .NET自然会全力支持此类编程开发,为此,下文将逐步阐述OL E DB的DB2开发。
OLE DB for DB2 驱动
首先,Visual Studio.NET和Wi ndows 2000 Server中并未直接提供DB2的OL E DB驱动,因此需下载Microsoft Host Int egration Server 2000软件,该软件包中含O LE DB Provider and ODBC driver for DB2,需下载Server端软件包,并在安装时选择 安装Data Integration,安装完成后就可使用其O LE DB的DB2驱动了。
设置数据库连接
首先,我们需配置好DB2的客户端设置,打开视图选单项中的服务 器资源管理器,在其数据连接中新增一个连接,指定程序选项时选择 Microsoft OLE DB Provider for DB2,下一步连接选项中,填写如下信息:
< br>
Data Source: QC DB(请酌情修改)
Network:TCP/I P
IP Address:数据库服务器地址
Network Port:DB2服务端口
Username:数据库访问权限的用户名
Password:该用户口令
Databa se initial Catalog:QCDB
Package collection:QCDB
default schema:Userid < br>
下一步高级 选项中选各自国家语言对应的code page及CCSID,最 后按确认键完成创建连接。
假设QCDB这个DB2数据 库中有一名为address的新数据表,其包含四个字段:nam e、email、age和address,我们可用服务器资源管 理器打开上述连接及该数据表,可输入数条中文记录,确定中文字符 能否正常显示。
为项目增加数据库连接
用Vis ual Studio新建一个ASP.NET项目,激活服务器资 源管理器的上述连接,用鼠标将该连接拖至新建的Web Form 上,则OLE DB需要的连接字符参数全部自动写入Web Fo rm程序中,上述连接生成的语句如下:
this.oleDbConnect ion1.ConnectionString = @" ;
Provider=DB2OLEDB;
Cac he Authentication=False;
Integrated Security="
&q uot;
"
"
;
Passw ord=freebsd9;
Persist S ecurity Info=True;
User ID=userid;
Initial Catalog=qcd b;
Data Source=qcdb;
Mod e=ReadWrite;
Extended P roperties="
"
"
&q uot;
;
APPC Remote LU Al ias="
"
"
"
;
< br>
APPC Local LU Alias=&qu ot;
"
"
"
;
APPC Mode Name=QPCSUPP;
Network Transport Library=TCP IP;
Host CCSID=37;
PC Co de Page=1282;
Network A ddress=172.23.169.1;
Ne twork Port=4444;
Package Collec tion=qcdb;
Default Sche ma=userid;
Alternate TP Name=&q uot;
"
"
"
;
Process Binary as Character=F alse;
Units of Work=RUW "
用服务器资源管理器工具生成连接可避免错写各种 参数,从而可快速地实现数据库连接。
Web Form 显示数据库数据
为Web Form新增一个OleDbD ataAdapter类的对象oleDbDataAdapter 1,为其选择数据连接时选上面建立的连接如:qcdb.qcdb .userid,选择使用SQL语句,生成SQL语句如:Sel ect from address,最后提示完成。再为Web Form新增一个DataSet并命名为dataSet1用来 放查询得到的数据。新增一个显示数据用的DataGrid命名为 DataGird1,最后在Web Form的程序段中的Pag e_Init部分中增加如下代码:
< br>
oleDbConnection1.Op en();
//打开数据库连接
oleDbDataAdapter1.Fill(dataSet 1,"
Address"
);
//将得来的数据填入dataSet
Data Grid1.DataBind();
//绑定数 据
oleDbConnection1.Clos e();
//关闭连接
编译运行后,可见ad dress表中内容被显示于Web Form的DataBrid 中。OleDbConnection1等属性设置都在生成的We b Form设计代码中。
增加数据库数据
在W eb Form上新增对应字段数量个数的TextBox,及一个 button,为该按键增加Click响应事件代码如下:
this.ole DbInsertCommand1.CommandText = "
INSERT INTO ADDRESS(NAM E, EMAIL,
AGE, ADDRESS) VA LUES ('"
+TextBox1.Text+&q uot;
','"
+TextBox2.Text+&q uot;
','"
+TextBox3.Text+&q uot;
','"
+TextBox4.Text+&q uot;
')"
;
oleDbInse rtCommand1.Connection.Open();
< br>
//打开连接
oleDbInse rtCommand1.ExecuteNonQuery();
< br>
//执行该SQL语句
o leDbInsertCommand1.Connection. Close();
//关闭连接
实际编程中,我 们需注意SQL语句的单引号问题以及数字和字符串处理问题。 < br>删除数据库数据
在Web Form上新增一个T extBox5及一个按键,要执行删除时,在TextBox5中 填入要删除记录的name字段的值,然后按该按键执行删除。该按 键代码如下:
System.Data.OleDb.OleDbComman d oleDeleteCommand1 = new Syst em.Data.OleDb.OleDbCommand();
< br>
this.oleDbDataAdapter1. DeleteCommand = oleDeleteComma nd1;
//声明为oleDb命令
oleDeleteCommand1.CommandTex t="
DELETE FROM ADDRESS WH ERE NAME='"
+TextBox5.Text +"
'"
;
oleDele teCommand1.Connection = this.o leDbConnection1;
//指明连接
oleDeleteCommand1.Conn ection.Open();
//打开连接
oleDeleteCommand1.Execut eNonQuery();
//执行SQL语句< br>
oleDeleteCommand1.Conne ction.Close();
//关闭连接
对于增加、更新和删除操作后的DataGrid刷新,可执行类似 的Select SQL语句即可。
上述代码可供各种非 SQL Server数据库编程参考和使用,微软为此提供了如O LE DB Provider for Oracle、AS/4 00和VSAM等众多驱动,OLE DB方式确实提供了较ODB C方式更为广泛的数据存取范围,如可存取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环境中编译并 正常运行