DataTable,DataView和DataGrid中一些容易混淆的(6)

DataRelation myRelation = new DataRelation("myRelation",ParentColumn,ChildColumn,false); //根据父表,子表的相关列建立关系
  
  然后,通过关系,建立对应order表的BindingManagerBase:
  
  myBindingManagerBaseChild = this.BindingContext[myDataSet,"customers.myRelation"]; //这个数据源将解析为一个父表中的客户对应的所有的order
  
  这样,当对应Customer的BindingManagerBase的当前行改变时,对应order的BindingManagerBase也将跟着变化,他们之间的关系是由myRelation决定的,如下图:
  
  
  figure-5
  对应子表order的DataGrid显示对应父表中ALFKI 客户的所有order,当点击了“主表下移一行”按钮时,父表中的当前客户改变为ANATR时, 子表同样也改变为显示对应ANATR的所有order了
  
  ◆ 在程序中访问DataGrid中的内容
  
  DataTable中有数据行DataRow,而在DataGrid中没有行这个对象,这让人感到很不习惯,也觉得不够自然。在DataTable 中,一张表的层次结构很清楚,DataTable.Rows属性可以得到这张表所包含的所有行的行集,通过行集的索引DataRowCollection [index]就可以得到具体的一个DataRow,数据行的索引DataRow[index]又可以得到这一行的具体某一列的内容。
  而DataGrid 中就没有这么方便了,DataGrid只有两个属性可用,DataGrid.CurrentCell 属性,此属性返回一个DataGridCell类型的结构,DataGridCell结构指明此Cell所在的行号和列号。还有一个 DataGrid.Item 属性,此属性有两个重载:
  
  
  public object this[DataGridCell] //获取或设置指定的 DataGridCell 的值
  public object this[int, int] //获取或设置位于指定行和列的单元格的值
  
  可见,DataGrid中访问都是针对某个Cell进行的。经常的,我们需要从当前的Cell获得此Cell所对应的DataRow,比如界面中可能先选中DataGrid的某一行,或者某一个Cell,然后点击一个按钮,弹出一个新的窗口,窗口中显示这一行的所有单元的内容,并允许修改单元的值,最后保存关闭窗口。这就需要从当前的DataGrid所在的单元找到其所对应的DataTable所在的行和列。
  
  而DataGrid中显示的数据可能经过DataView的DataView.RowFilter属性、 DataView.RowStateFilter属性的过滤,还可能经过DataGrid本身根据各个列的正向和反向排序,所以DataGrid的 CurrentRowIndex属性所指示的行索引跟其对应的DataTable的行索引有很大的机会是不一样的,不能够根据DataGrid的 CurrentRowIndex去获取其对应的DataTable的行。
  
  这时BindingManagerBase又将发挥作用了,我们可以先建立一个对应此DataGrid绑定的数据源的BindingManagerBase,这样这个BindingManagerBase就可以管理这个数据源。
   //设置DataGrid的数据源
  dataGrid1.DataSource = myDataSet;
  dataGrid1.DataMember = "customers";
  //建立同DataGrid同样数据源的BindingManagerBase
  BindingManagerBase myBindingManagerBaseParent = this.BindingContext[myDataSet,"customers"];
  
  一旦建立了这个BindingManagerBase,就可以通过BindingManagerBase的当前行的属性来获取当前数据源的记录:
   //BindingManagerBase的Current返回数据源的对象,对于绑定到DataView的数据源,需要将此对象显式
  //的转换为 DataRowView类型
  DataRowView myDataRowView =(DataRowView) myBindingManagerBaseParent.Current
  
  这样,我们就可以从当前的Cell得到此Cell所在的DataRowView,DataRowView又可以通过DataRowView.Row属性及其方便的得到DataRow。
  
  如果还要进一步,想要得到此Cell所对应的DataTable的具体单元,就是不光要得到DataRow,还要知道这个Cell所对应的列。
  
  这又分两种情况:
  
  一是DataGrid未使用TableStyles来设置DataGrid要显示的列和格式,数据源DataView的所有列都将按照DataView本身的顺序显示出来,这样可以直接取得对应的列索引:
   //获取当前DataGrid单元的列索引,这个索引跟DataTable的索引是一样的
  Int ColumnNumber = DataGrid.CurrentCell.ColumnNumber;

另一种情况是DataGrid使用了TableStyles来设置DataGrid要显示的列和格式,这样DataGrid单元的列索引跟DataTable的索引就可能是不一样的了,这就要用DataGrid的TableStyles了:
   Int ColumnNumberDataGrid = DataGrid.CurrentCell.ColumnNumber; //获取当前DataGrid单元的列索引
  Int ColumnNumberDataTable = DataGrid.TableStyles[0].GridColumnStyles[ColumnNumberDataGrid].MappingName  

来源:http://www.002pc.com/master/College/Programming/aspnet/1324

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
DataGridView控件用法合集 1. DataGridView当前的单元格属性取得、变更 2. DataGridView编辑属性 3. DataGridView最下面一新追加行非表示 4. DataGridView判断当前选是否为新追加的行 5. DataGridView删除行可否设定 6. DataGridView不表示和删除 7. DataGridView宽度高度设置为不能编辑 8. DataGridView行高幅自动调整 9. DataGridView指定行冻结 10. DataGridView顺序变更可否设定 11. DataGridView行复数选择 12. DataGridView选择的行、、单元格取得 13. DataGridView指定单元格是否表示 14. DataGridView表头部单元格取得 15. DataGridView表头部单元格文字设定 16. DataGridView选择的部分拷贝至剪贴板 17. DataGridView粘贴 18. DataGridView单元格上ToolTip表示设定(鼠标移动到相应单元格上时,弹出说明信息) 19. DataGridView的ContextMenuStrip属性 20. DataGridView指定滚动框位置 21. DataGridView手动追加 22. DataGridView全体分界线样式设置 23. DataGridView根据单元格属性更改显示内容 24. DataGridView新追加行的行高样式设置る 25. DataGridView新追加行单元格默认设置 26. DataGridView单元格数据错误标签表示 27. DataGridView单元格内输入正确性判断 28. DataGridView单元格输入错误事件的捕获 29. DataGridView行排序(点击表头自动排序的设置) 30. DataGridView自动行排序(新追加也会自动排序) 31. DataGridView自动行排序禁止情况下的排序 32. DataGridView指定指定排序 33. DataGridView单元格样式设置 34. DataGridView文字表示位置的设定 35. DataGridView单元格内文字换行 36. DataGridView单元格DBNull表示的设定 37. DataGridView单元格样式格式化 38. DataGridView指定单元格颜色设定 39. DataGridView单元格文字字体设置 40. DataGridView根据单元格设定单元格样式 41. DataGridView设置单元格背景颜色 42. DataGridView行样式描画 43. DataGridView显示行号 44. DataGridView焦点所在单元格焦点框不显示的设定 45. DataGridView显示选择框CheckBox 46. DataGridView显示下拉框ComboBox 47. DataGridView单击打开下拉框 48. DataGridView显示按钮 49. DataGridView显示链接 50. DataGridView显示图像 51. DataGridView编辑单元格控件取得 52. DataGridView输入自动完成 53. DataGridView单元格编辑时键盘KEY事件取得 54. DataGridView下拉框(ComboBox)单元格编辑时事件取得 55. DataGridView下拉框(ComboBox)单元格允许文字输入设定 56. DataGridView根据不同在另一显示相应图片 57. DataGridView显示进度条(ProgressBar) 58. DataGridView添加MaskedTextBox 59. DataGridViewEnter键按下焦点移至旁边的单元格 60. DataGridView行集合化(Group)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值