标签:
使用codefirst查询当然是必不可少的,但有时不小心可能很简单的查询也会导致异常。
下面用codefirst做个示例简单演示下异常发生的场景:
var attendlist = db.Database.SqlQuery<AttendCountViewModel>("select STUDENTID,SUM(isnull(REALHOUR,0)) As REALHOUR from ATTEND_LIST where ATTENDDATE=‘" + geDate + "‘ and GOTIME is not null and GETOFFTIME is not null group by STUDENTID"); foreach (AttendCountViewModel item in attendlist) { STUDENT_INFO student = db.STUDENT_INFO.Find(item.STUDENTID); db.SaveChanges(); }
逻辑比较简单,就是首先查询一个AttendCountViewModel列表,并当作IEnumerable<AttendCountViewModel>对象进行读取的时候,在里面再进行查询操作,不出意外的话,程序会毫不留情的报错:
已有打开的与此 Command 相关联的 DataReader,必须首先将它关闭。
用Reflector查看OjbectQuery对象的GetEnumerator方法,不难找出异常的原因:由于Entity在读取数据的时候使用的是 DbDataReader进行读取,当作为IEnumuerable<T>对象MoveNext进行操作时,只是使用 DbDataReader进行一次Read操作,因此当查询的结果未完全读取完的时候,数据库连接一直被占用,当再次进行查询操作时便回出现上面的异常。
至于解决方案,网上很容易就能找到:
使用codefirst查询当然是必不可少的,但有时不小心可能很简单的查询也会导致异常。
下面用codefirst做个示例简单演示下异常发生的场景:
1
2
3
4
5
6
7
|
var attendlist = db.Database.SqlQuery<AttendCountViewModel>( "select STUDENTID,SUM(isnull(REALHOUR,0)) As REALHOUR from ATTEND_LIST where ATTENDDATE=‘" + geDate + "‘ and GOTIME is not null and GETOFFTIME is not null group by STUDENTID" ); foreach (AttendCountViewModel item in attendlist) { STUDENT_INFO student = db.STUDENT_INFO.Find(item.STUDENTID); db.SaveChanges(); } |
逻辑比较简单,就是首先查询一个AttendCountViewModel列表,并当作IEnumerable<AttendCountViewModel>对象进行读取的时候,在里面再进行查询操作,不出意外的话,程序会毫不留情的报错:
已有打开的与此 Command 相关联的 DataReader,必须首先将它关闭。
用Reflector查看OjbectQuery对象的GetEnumerator方法,不难找出异常的原因:由于Entity在读取数据的时候使用的是 DbDataReader进行读取,当作为IEnumuerable<T>对象MoveNext进行操作时,只是使用 DbDataReader进行一次Read操作,因此当查询的结果未完全读取完的时候,数据库连接一直被占用,当再次进行查询操作时便回出现上面的异常。
至于解决方案,网上很容易就能找到:
code first提示已有打开的与此 Command 相关联的 DataReader,必须首先将它关闭解决方法
标签:
原文地址:http://www.cnblogs.com/LoveQin/p/5643185.html