zoukankan      html  css  js  c++  java
  • 关于DataTable.Select方法偶尔无法正确查到数据的处理方法

      项目中经常用DataTable在内存中存储并操作数据,在进行报表开发的时候,报表的各种过滤功能用这个内存表可以大现身手,但最近在使用过程中却遇到一个奇怪的现象,现将该问题及处理方法记录一下。这是在做护士站的执行单的时候遇到过的,我使用DataTableSelect方法根据条件对内存表进行过滤,但是偶尔会出现非预期结果,如:

    1 string strFilter = "处方号={0}";
    2  strFilter = string.Format(strFilter, 123456);
    3  DataRow[] row = dsDrugList.Select(strFilter);

    dsDrugList中有处方号=123456的数据,但是最终的row没有得到处方号为123456,百思不得其解。

    因此查阅MSDN:

     获取 DataRow 对象的数组。

    名称

    说明

     

     

     

    Select()

    获取所有 DataRow 对象的数组。

     

     

    Select(String)

    按照主键顺序(如果没有主键,则按照添加顺序)获取与筛选条件相匹配的所有DataRow 对象的数组。

     

     

    Select(String, String)

    获取按照指定的排序顺序且与筛选条件相匹配的所有 DataRow 对象的数组。

     

     

    Select(String, String, DataViewRowState)

    获取与排序顺序中的筛选器以及指定的状态相匹配的所有 DataRow 对象的数组

    重点看下一个参数的重载方法:Select(String)

    按照主键顺序(如果没有主键,则按照添加顺序)获取与筛选条件相匹配的所有 DataRow 对象的数组。

    微软自己的示例:

     1 private void GetRowsByFilter()
     2 {
     3     DataTable table = DataSet1.Tables["Orders"];
     4     // Presuming the DataTable has a column named Date.
     5     string expression;
     6     expression = "Date > #1/1/00#";
     7     DataRow[] foundRows;
     8 
     9     // Use the Select method to find all rows matching the filter.
    10     foundRows = table.Select(expression);
    11 
    12     // Print column 0 of each returned row.
    13     for(int i = 0; i < foundRows.Length; i ++)
    14     {
    15         Console.WriteLine(foundRows[i][0]);
    16     }
    17 }

    嗯,并没有什么特别之处,晕乎了半小时。。。

    最终MSDN中该方法的备注说明引起了我的思考。

    若要创建 filterExpression 参数,请使用与应用于 DataColumn 类的 Expression 用来创建筛选器的属性值相同的规则。

    难道我传递进去的过滤表达式与DataTable中的“属性值规则”不一样?但会是什么不一样呢,因此询问大师兄,并将我的怀疑告之,大师兄看了后建议我将条件转换为字符串试试,试了下过不如其然。

    由于我的列“处方号”在数据库中是一个number类型,因此我通过filterExpression传递进去的参数没有加入引号,修改为如下即可完全正确select出期望的数据了。

    如下('{0}'占位符加单引号):

    1  string strFilter = "处方号='{0}'";
    2  strFilter = string.Format(strFilter, 123456);
    3  DataRow[] row = dsDrugList.Select(strFilter);
  • 相关阅读:
    动态加载配置文件
    Split Full Name as First and Last
    MM03物料主数据视图中某些视图或者某些字段的控制方法
    如何用《老友记》学英语?
    FOR ALL ENTRIES IN的用法
    [转载]MBEWH表数据更新逻辑
    如何学习《六人行》??
    英语口语练习方法
    SAP收货时自动创建采购订单
    BAPI_PO_CREATE1 创建采购订单时价格的处理函数
  • 原文地址:https://www.cnblogs.com/hangwq/p/3507952.html
Copyright © 2011-2022 走看看