原来是这么写的,可以看出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);
            }
posted on 2008-06-15 02:00  风孤鸿  阅读(1830)  评论(0编辑  收藏  举报