码迷,mamicode.com
首页 > 其他好文 > 详细

DataSource绑定DataTable.Select()显示system.data.DataRow问题解决办法

时间:2015-06-28 11:20:52      阅读:239      评论:0      收藏:0      [点我收藏+]

标签:datatable   dataview   datasource   select   listbox   

    有时候我们需要在控件中绑定DataTable中设定条件过滤后的数据,此时,在winForm环境中,一些控件不能正确绑定并显示数据内容,这是因为DataTable.Select()返回的是DataRow[]类型的行数组,没有行列相关架构值。而控件如ListBox、comboBox等不能识别行数组中的列,读不到行列架构值,所以无法正常显示。

    解决办法是用DataView进行转换,即在DataView中对DataTable过滤数据。DataView构造函数如下:

    DataView ( DataTable dt,  String RowFilter,  String SorColName,  DataViewRowState)


    dt 用于获取或设置源

    RowFilter 获取或设置用于筛选在 DataView 中查看哪些行的表达式

    SorColName 获取或设置 DataView 的一个或多个排序列以及排序顺序

    DataViewRowState 详细取值及功能见下表:

  Added 一个新行。
  CurrentRows 包括未更改行、新行和已修改行的当前行。 默认情况下,DataViewRowState 项设置当前行。
  Deleted 已删除的行。
  ModifiedCurrent 已修改的原始数据的当前版本(请参见 ModifiedOriginal)。
  ModifiedOriginal 已修改的数据的原始版本。(尽管此数据已被修改,它仍作为 ModifiedCurrent 可用)。
  None 无。
  OriginalRows 包括未更改行和已删除行的原始行。
  Unchanged 未更改的行。

  Count 在应用RowFilter后,获取DataView中的行数

    应用样例:

            DataTable jgbjlx = getDataTable( "jgbjlx");
            jgbjlxcomboBox.DisplayMember = "jgname";
            jgbjlxcomboBox.ValueMember = "id";
            jgbjlxcomboBox.DataSource = new DataView(jgbjlx , "id>0","id",DataViewRowState.CurrentRows);

    使用DataView还可以根据行的状态设置DataViewRowState,实现显示更改和已经删除的行、修改前的原始行、未更改的行等子集。

DataSource绑定DataTable.Select()显示system.data.DataRow问题解决办法

标签:datatable   dataview   datasource   select   listbox   

原文地址:http://blog.csdn.net/zhaochao888666/article/details/46669245

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!