C#使用SqlDataReader读取数据库数据时CommandBehavior.CloseConnection参数的作用

Posted 曲幽

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C#使用SqlDataReader读取数据库数据时CommandBehavior.CloseConnection参数的作用相关的知识,希望对你有一定的参考价值。

主要用在ExecuteReader(c)中,如果想要返回对象前不关闭数据库连接,须要用CommandBehavior.CloseConnection; CloseConnection解决了流读取数据模式下,数据库连接不能有效关闭的情况。当某个XXXDataReader对象在生成时使用了CommandBehavior.CloseConnection,那数据库连接将在XXXDataReader对象关闭时自动关闭。

由于流模式读取数据库的特点,在具体应用时很难确定数据库连接何时才能被关闭,因为读取的动作是连续进行的,下面是一个常见的数据访问层的静态方法:

/// <summary> 
/// 常见的获取SqlDataReader方法
/// 通常的数据访问层都会提供这个方法
/// </summary>
static SqlDataReader GetReader()
{
    //通过连接字符串获取连接
    SqlConnection con = new SqlConnection(conn_String);
    try
    {
        //打开连接,执行查询,并且返回SqlDataReader
        con.Open();
        SqlCommand cmd = con.CreateCommand();
        cmd.CommandText = Sql;
        SqlDataReader dr = cmd.ExecuteReader();
        //SqlDataReader dr = cmd.ExecuteReader(CommandBehavior.CloseConnection);
        return dr;
    }
    finally
    {
        //这里的代码处于两难的境地,如果这里执行关闭:con.Close();那返回的SqlDataReader将毫无用处,因为其依赖的连接已经关闭
        //如果这里不执行con.Close();那返回后该连接将永远无法关闭,因为调用方无法得到连接对象con,无法在调用处执行关闭
    }
}  

正如代码注释里描述的那样,这样的方法既不能关闭连接,也不能保持连接打开状态。很多系统为了解决这样两难的境地,只能放弃使用Reader模式的数据源,或者把连接对象交给方法调用者,以便进行关闭。
而CommandBehavior.CloseConnection的功能恰好就是为了避免类似的尴尬境地,它能够保证当SqlDataReader对象被关闭时,其依赖的连接也会被自动关闭CommandBehavior.

以上是关于C#使用SqlDataReader读取数据库数据时CommandBehavior.CloseConnection参数的作用的主要内容,如果未能解决你的问题,请参考以下文章

SqlDataReader 和 T-SQL:在使用来自 C# 的“异步”调用时使用“try...catch”和“throw”时不会传播异常

关于SqlDataReader使用的一点疑惑

使用 SQLDataReader 读取 IP 地址

c#中SqlDataReader dr = cmd.ExecuteReader();然后读取dr.read(),用了while循环,就一直循环了

如何在 JavaScript 中使用 C# SQLDataReader 对象

C# 在 SqlDataReader 中禁用自动格式化