关于c#中两个DataGrid绑定到主表和子表的数据同步问题
来源:互联网 发布:广州网络教育招生 编辑:程序博客网 时间:2024/06/05 20:04
在数据库编程中,我们常常要将主表和子表分别绑定到两个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的方法来进行的。
- 关于c#中两个DataGrid绑定到主表和子表的数据同步问题
- C#中DataGrid 重新绑定数据的代码
- C# WPF中DataGrid的数据绑定(Binding)
- DataGrid和itemRenderer中的控件的数据绑定问题
- DataGrid中DropDownList 的数据绑定
- datagrid中绑定需要处理的数据
- DataGrid中DropDownList 的数据绑定
- c# datagrid的绑定
- DataGrid的数据绑定
- 关于同步操作和数据同步的问题
- 关于寻找两个字符串中最长子序列的问题
- 关于C#中datagridview中的数据绑定
- FLEX中datagrid数据绑定
- C# WinForm 中ComboBox数据绑定的问题
- EasyUI中iframe嵌入页面,包含datagrid数据动态绑定,页面内容的高度自适应问题
- DataGrid和DataGridComboBoxColumn数据绑定
- 关于如何在datagrid的摸板列里面绑定数据
- 关于.Net中,在数据绑定日期格式的问题
- 字符串内容逆置
- 用Nhibernate怎么实现数据的添加、删除、修改简单程序
- 使用标准数据绑定语法代替 DataBinder.Eval 方法以提高性能
- 最近打CS
- 遭遇字节对齐的问题。
- 关于c#中两个DataGrid绑定到主表和子表的数据同步问题
- delphi 2005 update1 download
- 圣诞...
- 2004的圣诞(2004-12-25-4:00)
- 使用FSO修改文件特定内容的函数
- Kaspersky Anti-Virus for Windows File Servers 5.0.33
- Kaspersky Anti-Virus for Windows File Servers 4.5.0.104
- 刚回来
- IT版孔乙己(ZT)