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


        有时候我们须要在控件中绑定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,实现显示更改和已经删除的行、改动前的原始行、未更改的行等子集。

  • 相关阅读:
    listener中@Autowired无法注入bean的一种解决方法
    PBKDF2加密的实现
    springmvc集成shiro后,session、request是否发生变化
    java加密解密工具类
    springMVC中controller层方法中使用private和public问题
    密码强度正则表达式 – 必须包含大写字母,小写字母和数字,至少8个字符等
    Java判断两个时间相差的天数
    Java中Date、String、Calendar类型之间的转化
    JavaScript前端和Java后端的AES加密和解密(转)
    JS前端加密JAVA后端解密详解
  • 原文地址:https://www.cnblogs.com/mengfanrong/p/5190209.html
Copyright © 2020-2023  润新知