关于DataReader使用的问题

本文指出在使用SQLDataReader时常见的一个问题:在循环读取记录并达到指定数量后,并没有正确地结束读取操作,而是继续读取剩余记录直到全部读完才关闭资源。正确的做法应该是在满足条件时调用Command.Cancel()来终止后续不必要的读取。
ContractedBlock.gifExpandedBlockStart.gifCode
 using (IDataReader reader = ExecuteReader(cmd)) {
                
int index = 0;
                
while (reader.Read()) {
                    
if (index >= region.Start) {
                        item 
= new T();
                        item.LoadData(reader);
                        items.Add(item);
                        
if (items.Count == region.Size)
                        {
                            
break;
                        }
                    }
                    index
++;
                }
            }

 

以上代码看上去似乎没什么问题,事实存在的问题是比较严重的。按道理break后紧接就是reader的关闭和释放,但在SqlDataReader确是把所有记录都read以后才会关闭和释放。正确的做法应该在break前调用Command.Cancel()方法取消继续执行。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值