原来是这么写的,可以看出provincetemp.GetModel(idofprovince)是model里面得到一个对象,有数据库操作.但是经过这一句后跳到provinceList.Add(provincetemp);
时发现datareader已经isclosed==true了,以前没有遇到过.在一个函数里面reader就没有问题,但是在while里面如果会跳到另一个文件,再跳回来就close了?不知道是所有datareader的问题,还是mysql的有问题?
MySqlDataReader readerProvince = DbOperate.getDataReader(sql);
while (readerProvince.Read())
{
int idofprovince =Convert.ToInt32(readerProvince["idofprovince"]);
province provincetemp = new province(); ;
provincetemp.GetModel(idofprovince);
provinceList.Add(provincetemp);
}
后来改成下面就没有问题了.......
DataSet ds=DbOperate.getDataSet(sql);
for (int i = 0; i < ds.Tables[0].Rows.Count; i++)
{
int idofprovince = Convert.ToInt32(ds.Tables[0].Rows[i]["idofprovince"]);
province provincetemp = new province(); ;
provincetemp.GetModel(idofprovince);
provinceList.Add(provincetemp);
}
转载于:https://www.cnblogs.com/shitougod/archive/2008/06/15/1222201.html