加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

c# – 如何正确使用SqlDataReader?

发布时间:2020-12-16 01:56:40 所属栏目:百科 来源:网络整理
导读:我有两种方法如下: internal static SqlDataReader SelectData(string sql){ using (var sqlConnection = new SqlConnection(Constant.ConnectionString)) { sqlConnection.Open(); var sqlCommand = new SqlCommand(sql,sqlConnection); var dataReader =
我有两种方法如下:

internal static SqlDataReader SelectData(string sql)
{
    using (var sqlConnection = new SqlConnection(Constant.ConnectionString))
    {
        sqlConnection.Open();
        var sqlCommand = new SqlCommand(sql,sqlConnection);
        var dataReader = sqlCommand.ExecuteReader();
        return dataReader;
    }
}

============

并使用此方法:

var dataReader = SelectData(---some sql ---);

private void AddData(dataReader)
{
    while (dataReader.Read())
    {
        Employee e = new Employee();
        e.FirstNamei = dataReader["Name"].ToString();
    }

    dataReader.Close();
}

我知道我们可以合并这两种方法,但我正在寻找更好的方法来写这个,或者这可能会导致一些问题?

解决方法

实际上你实际上是在让自己开放一点.你真的想这样写:

using (SqlConnection cnn = new SqlConnection(cnnString))
using (SqlCommand cmd = new SqlCommand(sql,cnn))
{
    // use parameters in your SQL statement too,so you can do this
    // and protect yourself from SQL injection,so for example
    // SELECT * FROM table WHERE field1 = @parm1
    cmd.Parameters.AddWithValue("@parm1",val1);

    cnn.Open();
    using (SqlDataReader r = cmd.ExecuteReader())
    {

    }
}

因为你需要确保这些物体被处置掉.此外,通过这个方向,您不需要dataReader.Close().当它被using语句自动处理时,它将被调用.

现在,将这些语句集合包装在try … catch中,然后你就可以了.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读