今天晚上这个问题困恼了我两个多小时。真是郁闷死了。最后还是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 方法,否则会一直处于此状态