DataTable.Select方法的性能问题

此博客为转载内容,原链接为https://www.cnblogs.com/mancini/archive/2005/12/27/305584.html ,标签涉及C#和大数据。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

我们首先看一个例子:
bool a,b,c,d; a=true;b=false;c=false;d=false;
如果我们执行if(a or b or c or d){},我们发现当程序执行到a,发现为true就执行下面的语句了,就没必要去判断b,c,d的值了。

最近在做一些大数据量的多次比较问题,由于多次比较一些记录块,所以将这些记录放到了DataTable中提高查找的性能,使用DataTable.Select(string filterExpression)来查找相关的记录。但是我发现执行的比较慢。然后我把Select方法接受的xpath拆分为几个条件执行,将其中最可能缩小范围的条件传递给filterExpression,然后在找到的集合中过滤其他的条件。发现这样比原来的执行时间少了很多。由此我估计Select算法是运算所有的条件,然后才返回这个记录的。
事不宜迟,我用Reflector.exe查看算法源代码,发现该方法是把这个filterExpression表达式分割成多个表达式,然后遍历记录,计算这些子条件,取到满足条件的记录(算法内部比较复杂,细节上没看完,如果有好的见解欢迎提出),这样就导致了效率的低下。
然后我又做了一个简单的例子验证了一下:
 1None.gifDataTable dt = new DataTable();
 2None.gif        dt.Columns.Add("a",typeof(int));
 3None.gif        dt.Columns.Add("b",typeof(string));
 4None.gif        
 5None.gif        for(int i=0;i<1000000;i++)
 6ExpandedBlockStart.gifContractedBlock.gif        dot.gif{
 7InBlock.gif            DataRow row = dt.NewRow();
 8InBlock.gif            row["a"= 0;
 9InBlock.gif            row["b"= "2";
10InBlock.gif            dt.Rows.Add(row);
11ExpandedBlockEnd.gif        }

12None.gif        long tick = System.DateTime.Now.Ticks;
13None.gif        DataRow[] rows = dt.Select("a=0 or (b='1' or b='3' or b='5' or b='6')");
14None.gif        System.Console.WriteLine((System.DateTime.Now.Ticks-tick));
15None.gif        tick = System.DateTime.Now.Ticks;
16None.gif        rows = dt.Select("a=0");
17None.gif        System.Console.WriteLine((System.DateTime.Now.Ticks-tick));
在本机测试,发现第一个执行时间是第二个的12倍!

所以在使用该方法时要注意优化自己的查询条件,尤其某个条件能有效的缩小查询范围时应该考虑先用该条件查询,然后对结果再执行条件。

转载于:https://www.cnblogs.com/mancini/archive/2005/12/27/305584.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值