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中,然后你就可以了. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |