在《Visual C#的数据绑定》中,已经了解了如何把数据集中的某些字段绑定到WinForm组件的某个属性上,这样程序员就可以根据以WinForm组件的来定制数据显示的形式,并且此时的WinForm组件显示内容就可以随着记录指针的变化而改变。至此可见,浏览数据记录的关键就是如何改变记录指针。要实现这种操作,就要使用到BindingManagerBase类,此类的主要作用是管理对于那些实现了对同一个数据源进行绑定的对象。说的具体些,就是能够使得Windows窗体上的已经对同一数据源进行数据绑定的组件保持同步。在BindingManagerBase类中定义了一个属性"Position",通过这个属性就可以改变BindingManagerBase对象中的数据指针。创建BindingManagerBase对象必须要使用到BindingContext类,其实每一个由Control类中继承而得到的对象,都有单一的BindingContext对象,在大多数创建窗体中实现数据绑定组件的BindingManagerBase对象是使用Form类的BindingContext来得到。下列代码是以Access 2000数据库为模型,创建的一个名称为"myBind"的BindingManagerBase对象。
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 ( ) ;
BindingManagerBase myBind = this.BindingContext [ myDataSet , "person" ] ;

解决方案 »

  1.   

    可以使用Form的BindingContext成员。
      

  2.   

    程序执行的效果就是:WinForm上的多个TextBox控件显示数据库某个表中一个记录,它们的数据源绑定在一个Dataset上,当按下“删除”按钮时,数据库表中的记录是删掉了,但是控件里还显示着(因为DataSet并没有更新),我希望从WinForm上就能看到删除的效果,即:DataSet也会更新
    看到有关文章说,用:
    myDataSet.Tables["LOG"].Rows[myBind.Position].Delete();
               //其中myBind是BindingManagerBase类的实例
    myDataSet.Tables["LOG"].AcceptChanges();
    但我不知道如何声明BindingManagerBase类的实例myBind,BindingManagerBase类是一个抽象类不能直接实例化,需要用到BindingContext类,我不知道该怎么用
    能帮忙解决我的问题吗?谢谢
      

  3.   

    BindingManagerBase  myBind  =  this.BindingContext  [  myDataSet  ,  "person"  ]  ;不就是这一句吗?你说呢?reanna.
      

  4.   

    但是编译时出错:“不包含BindingContext 定义”