已有打开的与此命令相关联的 DataReader,必须首先将它关闭

  今天晚上这个问题困恼了我两个多小时。真是郁闷死了。最后还是Google出来的。其实回想起来,还是心有一点浮躁造成的,如果心再静一点,是可以早点调试出来的。

  做的是一个登陆成功后显示所有书籍信息,使用了三层,BLL(业务层),DAL(数据层),Model,页面使用GridView + ObjectDataSource 显示数据.

 很明显,这个异常说的是先前有个DataReader已经打开了,必须先把它给关闭掉。是的,我打开DataReader两次。一次是登陆的时候,一次是显示所有书籍信息的时候。问题的根结就在第一次打开DataReader后要记得把它给关闭掉,释放资源。正确的做法是:

using (SqlDataReader reader = DBHelper.GetDataReader(sql))
{
      while (reader.Read())
       {
                    Users user = new Users();
                    user.Username = reader["LoginId"] as string;
                    user.Password = reader["LoginPwd"] as string;
                    userList.Add(user);
        }
}

 using的好处就在于可以执行完后释放资源

 

 

经测试--OK

 

MSDN的解释:在使用 SqlDataReader 时,关联的 SqlConnection 正忙于为 SqlDataReader 服务,对 SqlConnection 无法执行任何其他操作,只能将其关闭。除非调用 SqlDataReader Close 方法,否则会一直处于此状态

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值