在数据库编程中,我们常常要将主表和子表分别绑定到两个DataGrid,同时还有一些TextBox之类的
控件要显示相应DataGrid中的数据,这时候数据的同步就成了一个问题。这个问题的解决方法就是
使用BindingManagerBase来管理数据了。在DataSet中的两个表之间添加关系
private void CreateRelation(Dataset ds,string relationname,string MasterTableName,string SlaveTableName,string ColumnName)//
{
ds.Tables[MasterTableName].ChildRelations.Add(relationname,ds.Tables
MasterTableName].Columns [ColumnName],ds.Tables[SlaveTableName].Columns[ColumnName]);
}
这样就给主表MasterTable添加了一个子关系(ChildRelation)。
建立两个BindingManagerBase:
BindingManagerBase bmMaster=MasterGrid.BindingContext[ds,”MasterTableName”];
BindingManagerBase bmSlave=
SlaveGrid.BindingContext[ds,”MasterTableName.relationname”];
建立好BindingManagerBase之后,指定DataGrid的DataSource(最好是用SetDataBinding来进行绑定,指明DataMember。如果你用DataGrid.DataSource=ds.Tables[”TableName”]的话,对于子表对应的BindingManagerBase就起不了作用了,我也不知道是什么原因。应该是SlaveGrid.BindingContext[ds,”MasterTableName.relationname”]的问题吧)
MasterGrid.SetDataBinding(ds,”MasterTableName”);
SlaveGrid.SetDataBinding(ds,”SlaveTableName”);
这时候MasterGrid跟SlaveGrid已经对应起来了。
再绑定SlaveGrid对应的TextBox(比如说对应于Name列)
TextBoxName.DataBindings.Add(”Text”,ds,”MasterTableName.relationname.Name”);
注意带下划线的部分,不是用Add(”Text”,ds.Tables[SlaveTablename],”Name”)
也就是说,建立DataBindingManager,绑定数据到DataSet及TextBox时都是以相应的relation作为DataMember的,而不是用只指定DataSource的方法来进行的。