奇怪的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);
            }

转载于:https://www.cnblogs.com/shitougod/archive/2008/06/15/1222201.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值