关于c#中两个DataGrid绑定到主表和子表的数据同步问题

王朝c#·作者佚名  2006-01-09
窄屏简体版  字體: |||超大  

在数据库编程中,我们常常要将主表和子表分别绑定到两个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的方法来进行的。

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有  導航