SqlDataReader 提前终止的性能问题

作者:eaglet

SqlDataReader 对象可以逐行读取数据信息,但如果有10000行数据而我们只希望读取前面的100行数据,读取完后调用 SqlDataReader.Close 会非常慢。实际上调用SqlDataReader.Close 时SqlDataReader 会把后面的9900行数据全部读完才结束。

这个问题的解决办法是在SqlDataReader.Close 前调用 SqlCommand.Cancel ,取消当前命令。

代码如下:

SqlConnection _Conn; SqlDataReader _DataReader; SqlCommand _Command; public void OpenDataReader(string queryString) { _Command = new SqlCommand(queryString, _Conn); _DataReader = _Command.ExecuteReader(); } public void Dispose() { try { if (_Conn != null) { _Command.Cancel(); _DataReader.Close(); if (_Conn.State != ConnectionState.Closed && _Conn.State != ConnectionState.Broken) { _Conn.Close(); } _Conn = null; } } catch { } }

你可能感兴趣的:(SqlDataReader 提前终止的性能问题)