新客网WWW.XKER.COM:致力做中国最专业的网络学院!
学院: 操作系统 - 网络应用 - 服务器 - 网络安全 - 工具软件 - 办公软件 - Web开发 - 数据库 - 网页设计 - 图形图像 - 媒体动画 - 硬件学堂 - 存储频道 - QQ专区
您的位置:首页 > 软件开发 > .Net开发 > Asp.net教程 > 正文:关于c#中两个DataGrid绑定到主表和子表的数据同步问题

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

新客网 XKER.COM 2004-12-28 来源: 收藏本文
在数据库编程中,我们常常要将主表和子表分别绑定到两个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的方法来进行的。


收藏】 【评论】 【推荐】 【投稿】 【打印】 【关闭
发表评论
要记得去论坛讨论,点击注册新会员匿名评论
评论内容:不能超过250字,需审核后才会公布,请自觉遵守互联网相关政策法规。
阅读排行
随机推荐
实用信息推荐