A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 飞翔的33 中级黑马   /  2012-7-26 23:06  /  1714 人查看  /  1 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

使用ExecuteReader查询方法,返回SqlDataReader类型对象,如果想要获取输出参数的值,必须先调用SqlDataReader对象的Close()方法,而我在执行查询命令的时候设置了SqlConnection连接会随着SqlDataReader对象的关闭而关闭,那么现在是获取输出参数的值之前必须关闭SqlDataReader对象还是关闭SqlConnection连接,为什么?

评分

参与人数 1技术分 +1 收起 理由
郑文 + 1

查看全部评分

1 个回复

倒序浏览
1、当SqlDataReader没有关闭之前,数据库连接会一直保持open状态,所以在使用SqlDataReader时,使用完毕应该马上调用SqlDataReader.Close()关闭它。
2、使用完SqlDataReader后,你可以在程序中显示的调用数据库连接对象的Close方法关闭连接;
3,也可以在调用Command对象的ExecuteReader方法时传递CommandBehavior.CloseConnection 这个枚举变量,这样在调用SqlDataReader的Close方法时会自动关闭数据库连接。

评分

参与人数 1技术分 +1 收起 理由
宋天琪 + 1

查看全部评分

回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马