实战VisualC#数据库编程

实战VisualC#数据库编程


文/阿虎  出处/网络  
[编者的话:]关于数据库编程,微软提供了一个统一的数据对象访问模型,在Visual Studio6.0中称为ADO,在.NET中则统一为ADO.NET,掌握ADO.NET就等于掌握了数据库编程的核心,因此有必要首先复习一下以前发表的《ADO.NET完全攻略》。
  针对数据库编程始终是程序设计语言的一个重要方面的内容,也是一个难点。数据库编程的内容十分丰富,但最为基本编程的也就是那么几点,譬如:连接数据库、得到需要的数据和针对数据记录的浏览、删除、修改、插入等操作。其中又以后面针对数据记录的数据操作为重点。本文就来着重探讨一下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对象的另外一个重要的属性,是数据集记录的总数。 


  三.实现删除记录:
  在对数据记录进行操作的时候,有二点必须十分清晰: 
  其一:在对数据记录进行操作的时候,我想有一些程序员一定有这样一个疑惑,当对数据库服务器请求数据集的时候,就会产生"DataSet"对象,用以管理数据集,这样如果这些对数据库服务器的请求非常多,同样也就会产生很多的"DataSet"对象,达到一定时候必然会使得数据库服务器崩溃。这种想法是自然的,但和实际并不相符,因为"DataSet"对象并不是在服务器端产生的,而是在客户端产生的。所以面对众多的数据请求的时候对数据库服务器的影响并不十分太大。 
  其二:记得在用Delphi编写三层数据模型的时候的,每一次对数据库的修改其实只是对第二层产生的数据集的修改,要真正修改数据库,还必须调用一个另外的方法。在用ADO.NET处理数据库的时候,虽然处理的直接对象是数据库,但此时"DataSet"对象中的内容并没有随之改变,而绑定的数据组件显示的数据又来源于"DataSet"对象,这样就会产生一个错觉,就是修改了的记录并没有修改掉,删除的记录并没有删除掉。所以对数据记录进行操作的时候,在修改数据库后,还要对"DataSet"对象进行必要的修改,这样才能保证"DataSet"对象和数据库内容一致、同步。下面代码是删除当前绑定组件显示的记录的程序代码,此代码是以Access 2000数据库为模板的: 
protected void Delete_record ( object sender , System.EventArgs e )

  {

  DialogResult r = MessageBox.Show ( "是否删除当前记录!" , "删除当前记录!" , MessageBoxButtons.YesNo , MessageBoxIcon.Question ) ;

  int ss = ( int ) r ;

    if ( ss == 6 ) // 按动"确定"按钮

  {

  try{

  file://连接到一个数据库

  string strCon = " Provider = Microsoft.Jet.OLEDB.4.0 ; Data Source = db.mdb " ;

  OleDbConnection myConn = new OleDbConnection ( strCon ) ;

  myConn.Open ( ) ;

  string strDele = "DELETE FROM person WHERE id= "  t_id.Text ;

  OleDbCommand myCommand = new OleDbCommand ( strDele , myConn ) ;

  file://从数据库中删除指定记录

  myCommand.ExecuteNonQuery ( ) ;

  file://从DataSet中删除指定记录

  myDataSet.Tables [ "person" ] . Rows [ myBind.Position ] . Delete ( ) ;

  myDataSet.Tables [ "person" ] . AcceptChanges ( ) ;

  myConn.Close ( ) ;

  }

  catch ( Exception ed )

  {

  MessageBox.Show ( "删除记录错误信息: "  ed.ToString ( ) , "错误!" ) ;

  }

  }

  } 
  下面代码是删除当前绑定组件显示的记录的程序代码,此代码是以Sql Server 2000数据库为模板的,二者的区别仅仅在于数据链接: 
protected void Delete_record ( object sender , System.EventArgs e )

  {

  DialogResult r = MessageBox.Show ( "是否删除当前记录!" , "删除当前记录!" , MessageBoxButtons.YesNo , MessageBoxIcon.Question ) ;

  int ss = ( int ) r ;

    if ( ss == 6 ) // 按动"确定"按钮

  {

  try{

  // 设定数据连接字符串,意思是打开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 strDele = "DELETE FROM person WHERE id= "  t_id.Text ;

  OleDbCommand myCommand = new OleDbCommand ( strDele , myConn ) ;

  file://从数据库中删除指定记录

  myCommand.ExecuteNonQuery ( ) ;

  file://从DataSet中删除指定记录

  myDataSet.Tables [ "person" ] . Rows [ myBind.Position ] . Delete ( ) ;

  myDataSet.Tables [ "person" ] . AcceptChanges ( ) ;

  myConn.Close ( ) ;

  }

  catch ( Exception ed )

  {

  MessageBox.Show ( "删除记录错误信息: "  ed.ToString ( ) , "错误!" ) ;

  }

  }

  } 
  在这二段代码中,在更改数据库的同时也对"DatsSet"对象进行了必要的修改。

  下图是程序中对数据记录进行删除操作的运行界面:

 
  图01:删除记录 


四.插入数据记录:



   对数据库进行插入记录操作和删除记录操作基本的思路是一致的,就是通过ADO.NET首先插入数据记录到数据库,然后对"DataSet"对象进行必要的修改。下列代码就是以Access 2000数据库为模型修改当前记录的代码:




 
        protected void Update_record ( object sender , System.EventArgs e )

      {

      int i = myBind.Position ;

      try{

      file://连接到一个数据库

      string strCon = " Provider = Microsoft.Jet.OLEDB.4.0 ; Data Source = db.mdb " ;

      OleDbConnection myConn = new OleDbConnection ( strCon ) ;

      myConn.Open ( ) ;

      myDataSet.Tables [ "person" ] . Rows [ myBind.Position ] . BeginEdit ( ) ;

      file://从数据库中修改指定记录

      string strUpdt = " UPDATE person SET xm = '"

        t_xm.Text  "' , xb = '"

        t_xb.Text  "' , nl = "

        t_nl.Text  " , zip = "

        t_books.Text  " WHERE id = "  t_id.Text ;

      OleDbCommand myCommand = new OleDbCommand ( strUpdt , myConn ) ;

      myCommand.ExecuteNonQuery ( ) ;

      myDataSet.Tables [ "person" ] . Rows [ myBind.Position ] . EndEdit ( ) ;

      myDataSet.Tables [ "person" ] . AcceptChanges ( ) ;

      myConn.Close ( ) ;

      }

      catch ( Exception ed )

      {

      MessageBox.Show ( "修改指定记录错误: "  ed.ToString ( ) , "错误!" ) ;

      }

      myBind.Position = i ;

      }

 感谢原创者的辛勤劳动,希望对您有所帮助,转载请注明原出处。
 您可能对 [ADO.Net] 的这些文章也感兴趣:

ADO.NET Data Service
SQL Server 2005 - 实作CLR存储过程
用C#对ADO.NET数据库完成简单操作
用C#开发PocketPC数据库应用程序
ADO.NET Entity Framework:lazy loading(二)
在ADO.NET数据集中浏览多个相关表(1)
在ADO.NET数据集中浏览多个相关表(3)
DataTable,DataView和DataGrid中一些容易混淆的概念
当DataSet中包含主/子表时,Update更新步骤
ADO.NET Entity Framework 体验:语言