因海关业务复杂,数据量极大,在做sql自定义查询的时候需要限定返回结果集DataSet的数据量,微软本身的DataAdpter的Fill方法根本无法满足其需要,所以得自己想法实现,再自己实现了IDataReader转换为DataSet的方法后,发现在调用DataReader.Close的时候老是报“超时异常”。仔细翻阅了MSDN对Close方法的说明后,在备注的地方发现了这么一段话:
Close 方法填写输出参数的值、返回值和 RecordsAffected,从而增加了关闭用于处理大型或复杂查询的 SqlDataReader 所用的时间。如果返回值和查询影响的记录的数量不重要,则可以在调用 Close 方法前调用关联的 SqlCommand 对象的 Cancel 方法,从而减少关闭 SqlDataReader 所需的时间。
DataReader为了计算RecordsAffected值,在Close之前会继续读取剩下的记录,直到读完为止。原来执行Command的Cancel方法就可以解决这个问题。
下面是我的测试函数代码(仅供参考):
代码如下 | 复制代码 |
|
解决问题,效率也还可以。
注:之所以不用实体和高效率的分页方法,是因为sql语句为业务人员自己写的,无法确定有哪些字段,语句复杂度也无法确定,所以采用此方法。
恋爱进行时九游版
恋爱进行时九游版是一款以模拟恋爱玩法为核心的角色扮演手游,精
皇室对决fr(Null’s Royale)
皇室对决fr,即皇室战争的私服变态版本,在该版本中玩家能够拥
养了个猫联机版游戏
养了个猫小游戏一个猫咪主题的模拟经营类型的手游,在游戏中我那
模拟山羊收获日小米版
模拟山羊收获日小米版是一个极其魔性的手机游戏,在游戏中玩家将
女配逆袭之素衣
女配逆袭之素衣是一款恋爱养成冒险的一款游戏,可以角色扮演,在