相关疑难解决方法(0)

将围绕DataReader放置一个"using"语句关闭吗?

我经常写这样的DataReader代码:

try
{
    dr = cmd.ExecuteReader(CommandBehavior.SingleResult);
    while (dr.Read())
    {
        // Do stuff
    }
}
finally
{
    if (dr != null) { dr.Close(); }
}
Run Code Online (Sandbox Code Playgroud)

它是安全的替代try,并finally只用using各地块DataReader的创作?我想知道的原因是因为在所有微软的例子中我都看到他们使用了一个用于连接的但是总是明确地调用Close()DataReader.

Heres是使用DataReader检索数据的一个例子 (ADO.NET):

static void HasRows(SqlConnection connection)
{
    using (connection)
    {
        SqlCommand command = new SqlCommand(
          "SELECT CategoryID, CategoryName FROM Categories;",
          connection);
        connection.Open();

        SqlDataReader reader = command.ExecuteReader();

        if (reader.HasRows)
        {
            while (reader.Read())
            {
                Console.WriteLine("{0}\t{1}", reader.GetInt32(0),
                    reader.GetString(1));
            }
        }
        else …
Run Code Online (Sandbox Code Playgroud)

.net c# ado.net

25
推荐指数
1
解决办法
1万
查看次数

标签 统计

.net ×1

ado.net ×1

c# ×1