针对数据库编程始终是程序设计语言的一个重要方面的内容,也是一个难点。数据库编程的内容十分丰富,但最为基本编程的也就是那么几点,譬如:连接数据库、得到需要的数据和针对数据记录的浏览、删除、修改、插入等操作。其中又以后面针对数据记录的数据操作为重点。本文就来着重探讨一下 Visual C #数据库基本编程,即:如何浏览记录、修改记录、删除记录和插入记录。
一.程序设计和运行的环境设置:
( 1 ) . 视窗 2000 服务器版
( 2 ) .Microsoft Data Acess Component 2.6 以上版本 ( MDAC 2.6 )
( 3 ) ..Net FrameWork SDK Beta 2
为了更清楚的说明问题,在数据库的选用上,采用了当前比较典型的数据库,一个是本地数据库 Access 2000 ,另外一个是远程数据库 Sql Server 2000 。其中本地数据库名称为 "db.mdb" ,在其中定义了一张数据表 "person" , "person" 表的数据结构如下表:
字段名称 字段类型 字段意思
id 数字 序号
xm 文本 姓名
xb 文本 性别
nl 文本 年龄
zip 文本 邮政编码
远程数据库 Sql Server 2000 的数据库服务器名称为 "Server1", 数据库名称为 "Data1" ,登陆的 ID 为 "sa" ,口令为空,在数据库也定义了一张 "person" 表,数据结构如上表。
二.如何浏览数据:
在《 Visual C #的数据绑定》中,已经了解了如何把数据集中的某些字段绑定到 WinForm 组件的某个属性上,这样程序员就可以根据以 WinForm 组件的来定制数据显示的形式,并且此时的 WinForm 组件显示内容就可以随着记录指针的变化而改变。至此可见,浏览数据记录的关键就是如何改变记录指针。要实现这种操作,就要使用到 BindingManagerBase 类,此类的主要作用是管理对于那些实现了对同一个数据源进行绑定的对象。说的具体些,就是能够使得 Windows 窗体上的已经对同一数据源进行数据绑定的组件保持同步。在 BindingManagerBase 类中定义了一个属性 "Position" ,通过这个属性就可以改变 BindingManagerBase 对象中的数据指针。创建 BindingManagerBase 对象必须要使用到 BindingContext 类,其实每一个由 Control 类中继承而得到的对象,都有单一的 BindingContext 对象,在大多数创建窗体中实现数据绑定组件的 BindingManagerBase 对象是使用 Form 类的 BindingContext 来得到。下列代码是以 Access 2000 数据库为模型,创建的一个名称为 "myBind" 的 BindingManagerBase 对象。
// 创建一个 OleDbConnection
string strCon = " Provider = Microsoft.Jet.OLEDB.4.0 ; Data Source = db.mdb" ;
OleDbConnection myConn = new OleDbConnection ( strCon ) ;
string strCom = " SELECT * FROM person " ;
file:// 创建一个 DataSet
myDataSet = new DataSet ( ) ;
myConn.Open ( ) ;
file:// 用 OleDbDataAdapter 得到一个数据集
OleDbDataAdapter myCommand = new OleDbDataAdapter ( strCom , myConn ) ;
file:// 把 Dataset 绑定 books 数据表
myCommand.Fill ( myDataSet , "person" ) ;
file:// 关闭此 OleDbConnection
myConn.Close ( ) ;
myBind = this.BindingContext [ myDataSet , "person" ] ;
下列代码是以 Sql Server 2000 数据库为模型,创建一个名称为 "myBind" 的 BindingManagerBase 对象。
// 设定数据连接字符串,此字符串的意思是打开 Sql server 数据库,服务器名称为 server1, 数据库为 data1
string strCon = "Provider = SQLOLEDB.1 ; Persist Security Info = False ; User ID = sa ; Initial Catalog = data1 ; Data Source = server1 " ;
OleDbConnection myConn = new OleDbConnection ( strCon ) ;
myConn.Open ( ) ;
string strCom = " SELECT * FROM person " ;
file:// 创建一个 DataSet
myDataSet = new DataSet ( ) ;
file:// 用 OleDbDataAdapter 得到一个数据集
OleDbDataAdapter myCommand = new OleDbDataAdapter ( strCom , myConn ) ;
file:// 把 Dataset 绑定 person 数据表
myCommand.Fill ( myDataSet , " person " ) ;
file:// 关闭此 OleDbConnection
myConn.Close ( ) ;
myBind = this.BindingContext [ myDataSet , "person" ] ;
得到了是同一数据源的 BindingManagerBase 对象,通过改变此对象的 "Position" 属性值,这样绑定数据的组件显示的数据就随之变化,从而实现导航数据记录。
< I > . 导航按钮 " 上一条 " 实现方法:
protected void GoPrevious ( object sender , System.EventArgs e )
{
if ( myBind.Position == 0 )
MessageBox.Show ( " 已经到了第一条记录! " , " 信息提示! " , MessageBoxButtons.OK , MessageBoxIcon.Information ) ;
else
myBind.Position -= 1 ;
}
< II > . 导航按钮 " 下一条 " 实现方法:
protected void GoNext ( object sender , System.EventArgs e )
{
if ( myBind.Position == myBind.Count -1 )
MessageBox.Show ( " 已经到了最后一条记录! ", " 信息提示! " , MessageBoxButtons.OK , MessageBoxIcon.Information ) ;
else
myBind.Position += 1 ;
}
< III > . 导航按钮 " 至尾 " 实现方法:
protected void GoLast ( object sender , System.EventArgs e )
{
myBind.Position = myBind.Count - 1 ;
}
< IV > . 导航按钮 " 至首 " 实现方法:
protected void GoFirst ( object sender , System.EventArgs e )
{
myBind.Position = 0 ;
}
注释: "Count" 是 BindingManagerBase 对象的另外一个重要的属性,是数据集记录的总数。
三.实现删除记录:
1<p> 在对数据记录进行操作的时候,有二点必须十分清晰: </p>
1<p> 其一:在对数据记录进行操作的时候,我想有一些程序员一定有这样一个疑惑,当对数据库服务器请求数据集的时候,就会产生 "DataSet" 对象,用以管理数据集,这样如果这些对数据库服务器的请求非常多,同样也就会产生很多的 "DataSet" 对象,达到一定时候必然会使得数据库服务器崩溃。这种想法是自然的,但和实际并不相符,因为 "DataSet" 对象并不是在服务器端产生的,而是在客户端产生的。所以面对众多的数据请求的时候对数据库服务器的影响并不十分太大。 </p>
1<p> 其二:记得在用 Delphi 编写三层数据模型的时候的,每一次对数据库的修改其实只是对第二层产生的数据集的修改,要真正修改数据库,还必须调用一个另外的方法。在用 ADO.NET 处理数据库的时候,虽然处理的直接对象是数据库,但此时 "DataSet" 对象中的内容并没有随之改变,而绑定的数据组件显示的数据又来源于 "DataSet" 对象,这样就会产生一个错觉,就是修改了的记录并没有修改掉,删除的记录并没有删除掉。所以对数据记录进行操作的时候,在修改数据库后,还要对 "DataSet" 对象进行必要的修改,这样才能保证 "DataSet" 对象和数据库内容一致、同步。下面代码是删除当前绑定组件显示的记录的程序代码,此代码是以 Access 2000 数据库为模板的: </p>
1<p>protected void Delete_record ( object sender , System.EventArgs e )
2
3{
4
5DialogResult r = MessageBox.Show ( " 是否删除当前记录! " , " 删除当前记录! " , MessageBoxButtons.YesNo , MessageBoxIcon.Question ) ;
6
7int ss = ( int ) r ;
8
9if ( ss == 6 ) // 按动 " 确定 " 按钮
10
11{
12
13try{
14
15file:// 连接到一个数据库
16
17string strCon = " Provider = Microsoft.Jet.OLEDB.4.0 ; Data Source = db.mdb " ;
18
19OleDbConnection myConn = new OleDbConnection ( strCon ) ;
20
21myConn.Open ( ) ;
22
23string strDele = "DELETE FROM person WHERE id= " + t_id.Text ;
24
25OleDbCommand myCommand = new OleDbCommand ( strDele , myConn ) ;
26
27file:// 从数据库中删除指定记录
28
29myCommand.ExecuteNonQuery ( ) ;
30
31file:// 从 DataSet 中删除指定记录
32
33myDataSet.Tables [ "person" ] . Rows [ myBind.Position ] . Delete ( ) ;
34
35myDataSet.Tables [ "person" ] . AcceptChanges ( ) ;
36
37myConn.Close ( ) ;
38
39}
40
41catch ( Exception ed )
42
43{
44
45MessageBox.Show ( " 删除记录错误信息: " + ed.ToString ( ) , " 错误! " ) ;
46
47}
48
49}
50
51} </p>
1<p> 下面代码是删除当前绑定组件显示的记录的程序代码,此代码是以 Sql Server 2000 数据库为模板的,二者的区别仅仅在于数据链接: </p>
1<p>protected void Delete_record ( object sender , System.EventArgs e )
2
3{
4
5DialogResult r = MessageBox.Show ( " 是否删除当前记录! " , " 删除当前记录! " , MessageBoxButtons.YesNo , MessageBoxIcon.Question ) ;
6
7int ss = ( int ) r ;
8
9if ( ss == 6 ) // 按动 " 确定 " 按钮
10
11{
12
13try{
14
15// 设定数据连接字符串,意思是打开 Sql server 数据库,服务器名称为 server1, 数据库为 data1
16
17string strCon = "Provider = SQLOLEDB.1 ; Persist Security Info = False ; User ID = sa ; Initial Catalog = data1 ; Data Source = server1 " ;
18
19OleDbConnection myConn = new OleDbConnection ( strCon ) ;
20
21myConn.Open ( ) ;
22
23string strDele = "DELETE FROM person WHERE id= " + t_id.Text ;
24
25OleDbCommand myCommand = new OleDbCommand ( strDele , myConn ) ;
26
27file:// 从数据库中删除指定记录
28
29myCommand.ExecuteNonQuery ( ) ;
30
31file:// 从 DataSet 中删除指定记录
32
33myDataSet.Tables [ "person" ] . Rows [ myBind.Position ] . Delete ( ) ;
34
35myDataSet.Tables [ "person" ] . AcceptChanges ( ) ;
36
37myConn.Close ( ) ;
38
39}
40
41catch ( Exception ed )
42
43{
44
45MessageBox.Show ( " 删除记录错误信息: " + ed.ToString ( ) , " 错误! " ) ;
46
47}
48
49}
50
51} </p>
1<p> 在这二段代码中,在更改数据库的同时也对 "DatsSet" 对象进行了必要的修改。
2
3下图是程序中对数据记录进行删除操作的运行界面: </p>
1<p></p>