实战实战实战实战VisualC####数据库编程数据库编程数据库编程数据库编程((((上上上上))))[编者的话:]关于数据库编程,微软提供了一个统一的数据对象访问模型,在VisualStudio6.0中称为ADO,在.NET中则统一为ADO.NET,掌握ADO.NET就等于掌握了数据库编程的核心,因此有必要首先复习一下以前发表的《ADO.NET完全攻略》。针对数据库编程始终是程序设计语言的一个重要方面的内容,也是一个难点。数据库编程的内容十分丰富,但最为基本编程的也就是那么几点,譬如:连接数据库、得到需要的数据和针对数据记录的浏览、删除、修改、插入等操作。其中又以后面针对数据记录的数据操作为重点。本文就来着重探讨一下VisualC#数据库基本编程,即:如何浏览记录、修改记录、删除记录和插入记录。一.程序设计和运行的环境设置:(1).视窗2000服务器版(2).MicrosoftDataAcessComponent2.6以上版本(MDAC2.6)(3)..NetFrameWorkSDKBeta2为了更清楚的说明问题,在数据库的选用上,采用了当前比较典型的数据库,一个是本地数据库Access2000,另外一个是远程数据库SqlServer2000。其中本地数据库名称为db.mdb,在其中定义了一张数据表person,person表的数据结构如下表:字段名称字段类型字段意思id数字序号xm文本姓名xb文本性别nl文本年龄zip文本邮政编码远程数据库SqlServer2000的数据库服务器名称为Server1,数据库名称为Data1,登陆的ID为sa,口令为空,在数据库也定义了一张person表,数据结构如上表。二.如何浏览数据:在《VisualC#的数据绑定》中,已经了解了如何把数据集中的某些字段绑定到WinForm组件的某个属性上,这样程序员就可以根据以WinForm组件的来定制数据显示的形式,并且此时的WinForm组件显示内容就可以随着记录指针的变化而改变。至此可见,浏览数据记录的关键就是如何改变记录指针。要实现这种操作,就要使用到BindingManagerBase类,此类的主要作用是管理对于那些实现了对同一个数据源进行绑定的对象。说的具体些,就是能够使得Windows窗体上的已经对同一数据源进行数据绑定的组件保持同步。在BindingManagerBase类中定义了一个属性Position,通过这个xm.Text+',xb='+t_xb.Text+',nl=鯏D\属性就可以改变BindingManagerBase对象中的数据指针。创建BindingManagerBase对象必须要使用到BindingContext类,其实每一个由Control类中继承而得到的对象,都有单一的BindingContext对象,在大多数创建窗体中实现数据绑定组件的BindingManagerBase对象是使用Form类的BindingContext来得到。下列代码是以Access2000数据库为模型,创建的一个名称为myBind的BindingManagerBase对象。//创建一个OleDbConnectionstringstrCon=Provider=Microsoft.Jet.OLEDB.4.0;DataSource=db.mdb;OleDbConnectionmyConn=newOleDbConnection(strCon);stringstrCom=SELECT*FROMperson;file://创建一个DataSetmyDataSet=newDataSet();myConn.Open();file://用OleDbDataAdapter得到一个数据集OleDbDataAdaptermyCommand=newOleDbDataAdapter(strCom,myConn);file://把Dataset绑定books数据表myCommand.Fill(myDataSet,person);file://关闭此OleDbConnectionmyConn.Close();myBind=this.BindingContext[myDataSet,person];下列代码是以SqlServer2000数据库为模型,创建一个名称为myBind的BindingManagerBase对象。//设定数据连接字符串,此字符串的意思是打开Sqlserver数据库,服务器名称为server1,数据库为data1stringstrCon=Provider=SQLOLEDB.1;PersistSecurityInfo=False;UserID=sa;InitialCatalog=data1;DataSource=server1;OleDbConnectionmyConn=newOleDbConnection(strCon);myConn.Open();stringstrCom=SELECT*FROMperson;file://创建一个DataSetmyDataSet=newDataSet();file://用OleDbDataAdapter得到一个数据集OleDbDataAdaptermyCommand=newOleDbDataAdapter(strCom,myConn);file://把Dataset绑定person数据表myCommand.Fill(myDataSet,person);file://关闭此OleDbConnectionmyConn.Close();myBind=this.BindingContext[myDataSet,person];得到了是同一数据源的BindingManagerBase对象,通过改变此对象的Position属性值,这样绑定数据的组件显示的数据就随之变化,从而实现导航数据记录。,xb='+t_xb.Text+',nl=鯏D\I.导航按钮上一条实现方法:protectedvoidGoPrevious(objectsender,System.EventArgse){if(myBind.Position==0)MessageBox.Show(已经到了第一条记录!,信息提示!,MessageBoxButtons.OK,MessageBoxIcon.Information);elsemyBind.Position-=1;}II.导航按钮下一条实现方法:protectedvoidGoNext(objectsender,System.EventArgse){if(myBind.Position==myBind.Count-1)MessageBox.Show(已经到了最后一条记录!,信息提示!,MessageBoxButtons.OK,MessageBoxIcon.Information);elsemyBind.Position+=1;}III.导航按钮至尾实现方法:protectedvoidGoLast(objectsender,System.EventArgse){myBind.Position=myBind.Count-1;}IV.导航按钮至首实现方法:protectedvoidGoFirst(objectsender,System.EventArgse){myBind.Position=0;}注释:Count是BindingManagerBase对象的另外一个重要的属性,是数据集记录的总数。实战实战实战实战VisualC####数据库编程数据库编程数据库编程数据库编程((((中中中中))))三.实现删除记录:/PP在对数据记录进行操作的时候,有二点必须十分清晰:/PP其一:在对数据记录进行操作的时候,我想有一些程序员一定有这样一个疑惑,当对数据库服务器请求数据集的时候,就会产生DataSet对象,用以管理数据集,这样如果这些对数据库服务器的请求非常多,同样也就会产生很多的DataSet对象,达ind.Position+=1;到一定时候必然会使得数据库服务器崩溃。这种想法是自然的,但和实际并不相符,因为DataSet对象并不是在服务器端产生的,而是在客户端产生的。所以面对众多的数据请求的时候对数据库服务器的影响并不十分太大。/PP其二:记得在用Delphi编写三层数据模型的时候的,每一次对数据库的修改其实只是对第二层产生的数据集的修改,要真正修改数据库,还必须调用一个另外的方法。在用ADO.NET处理数据库的时候,虽然处理的直接对象是数据库,但此时DataSet对象中的内容并没有随之改变,而绑定的数据组件显示的数据又来源于DataSet对象,这样就会产生一个错觉,就是修改了的记录并没有修改掉,删除的记录并没有删除掉。所以对数据记录进行操作的时候,在修改数据库后,还要对DataSet对象进行必要的修改,这样才能保证DataSet对象和数据库内容一致、同步。下面代码是删除当前绑定组件显示的记录的程序代码,此代码是以Access2000数据库为模板的:/PPprotectedvoidDelete_record(objectsender,System.EventArgse){DialogResultr=MessageBox.Show(是否删除当前记录!,删除当前记录!,MessageBoxButtons.YesNo,MessageBoxIcon.Question);intss=(int)r;if(ss==6)//按动确定按钮{try{file://连接到一个数据库stringstrCon=Provider=Microsoft.Jet.OLEDB.4.0;DataSource=db.mdb;OleDbConnectionmyConn=newOleDbConnection(strCon);myConn.Open();stringstrDele=DELETEFROMpersonWHEREid=+t_id.Text;OleDbCommandmyCommand=newOleDbCommand(strDele,myConn);file://从数据库中删除指定记录myCommand.ExecuteNonQuery();file://从DataSet中删除指定记录myDataSet.Tables[person].Rows[myBind.Position].Delete();myDataSet.Tables[person].AcceptChanges();myConn.Close();}catch(Exceptioned){MessageBox.Show(删除记录错误信息:+ed.ToString(),错误!);}}}/PP下面代码是删除当前绑定组件显示的记录的程序代码,此代码是以SqlServer2000数据库为模板的,二者的区别仅仅在于数据链接:/PPprotectedvoidDelete_record(objectsender,System.EventArgse){DialogResultr=MessageBox.Show(是否删除当前记录!,删除当前记录!,MessageBoxButtons.YesNo,MessageBoxIcon.Question);intss=(int)r;int)r;if(ss==6)//按动确定按钮{try{//设定数据连接字符串,意思是打开Sqlserver数据库,服务器名称为server1,数据库为data1stringstrCon=Provider=SQLOLEDB.1;PersistSecurityInfo=False;UserID=sa;InitialCatalog=data1;DataSource=server1;OleDbConnectionmyConn=newOleDbConnection(strCon)