如何处理无法使用using语句的DataReader实例的复杂场景和解决方案?
- 内容介绍
- 文章标签
- 相关推荐
本文共计1109个文字,预计阅读时间需要5分钟。
原文介绍了一个关于`DataReader`无法使用`using`语句的示例,以下是对其的简化
csharp示例:展示如何使用`ExecuteMySqlReader`方法读取MySQL数据,不使用`using`语句。
本文介绍了DataReader不能使用using的详细示例,分享给大家,具有如下:
public static MySqlDataReader ExecuteMySqlReader(string sqlStr) { MySqlConnection conn = new MySqlConnection(MyConString); MySqlCommand cmd = new MySqlCommand(sqlStr, conn); try { conn.Open(); //执行CloseConnection命令时,如果关闭关联的DataReader对象,则关联的Connection对象也将关闭 //用using(conn)会报错,因为执行完命令就会关闭连接,其它代码调用DataReader对象时,连接已经关闭。 MySqlDataReader dr = cmd.ExecuteReader(CommandBehavior.CloseConnection); return dr; } catch (Exception exp) { throw new Exception(exp.Message); } }
PS:MySqlDataReader在Using中使用
结论:当DataReader放在Using方法中时,会自动释放资源,如果中途出现了异常处理,也同样会释放掉占用的资源。
本文共计1109个文字,预计阅读时间需要5分钟。
原文介绍了一个关于`DataReader`无法使用`using`语句的示例,以下是对其的简化
csharp示例:展示如何使用`ExecuteMySqlReader`方法读取MySQL数据,不使用`using`语句。
本文介绍了DataReader不能使用using的详细示例,分享给大家,具有如下:
public static MySqlDataReader ExecuteMySqlReader(string sqlStr) { MySqlConnection conn = new MySqlConnection(MyConString); MySqlCommand cmd = new MySqlCommand(sqlStr, conn); try { conn.Open(); //执行CloseConnection命令时,如果关闭关联的DataReader对象,则关联的Connection对象也将关闭 //用using(conn)会报错,因为执行完命令就会关闭连接,其它代码调用DataReader对象时,连接已经关闭。 MySqlDataReader dr = cmd.ExecuteReader(CommandBehavior.CloseConnection); return dr; } catch (Exception exp) { throw new Exception(exp.Message); } }
PS:MySqlDataReader在Using中使用
结论:当DataReader放在Using方法中时,会自动释放资源,如果中途出现了异常处理,也同样会释放掉占用的资源。

