已有打开的与此命令相关联的 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 方法,否则会一直处于此状态

 

你可能感兴趣的:(sql,Google)