最新下载
热门教程
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
asp.net中大数据导致DataReader.Close超时的异常
时间:2022-06-25 03:46:12 编辑:袖梨 来源:一聚教程网
因海关业务复杂,数据量极大,在做sql自定义查询的时候需要限定返回结果集DataSet的数据量,微软本身的DataAdpter的Fill方法根本无法满足其需要,所以得自己想法实现,再自己实现了IDataReader转换为DataSet的方法后,发现在调用DataReader.Close的时候老是报“超时异常”。仔细翻阅了MSDN对Close方法的说明后,在备注的地方发现了这么一段话:
Close 方法填写输出参数的值、返回值和 RecordsAffected,从而增加了关闭用于处理大型或复杂查询的 SqlDataReader 所用的时间。如果返回值和查询影响的记录的数量不重要,则可以在调用 Close 方法前调用关联的 SqlCommand 对象的 Cancel 方法,从而减少关闭 SqlDataReader 所需的时间。
DataReader为了计算RecordsAffected值,在Close之前会继续读取剩下的记录,直到读完为止。原来执行Command的Cancel方法就可以解决这个问题。
下面是我的测试函数代码(仅供参考):
代码如下 | 复制代码 |
|
解决问题,效率也还可以。
注:之所以不用实体和高效率的分页方法,是因为sql语句为业务人员自己写的,无法确定有哪些字段,语句复杂度也无法确定,所以采用此方法。
相关文章
- 沙石镇时光肥料怎么合成-详细方法介绍 05-05
- 新版cex交易所app 05-05
- cex数字货币交易所 05-05
- pi币挖矿app2024最新版本 05-05
- cex交易平台app下载2024最新版 05-05
- 火必网app官网正版 05-05