关于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);

 

 

 

转载于:https://www.cnblogs.com/hangwq/p/3507952.html

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值