奇怪的MySqlDataReader关闭问题?

 原来是这么写的,可以看出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);
            }

你可能感兴趣的:(reader)