我正在使用實體框架4.1查詢SQL Server 2008數據庫。不幸的是每次我們經常得到下面的異常:實體框架 - System.IndexOutOfRangeException
<ExceptionType>System.IndexOutOfRangeException, mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089</ExceptionType>
<Message>Index was outside the bounds of the array.</Message>
at System.Data.SqlClient.SqlDataReader.ReadColumnHeader(Int32 i)
at System.Data.SqlClient.SqlDataReader.IsDBNull(Int32 i)
at System.Data.Common.Internal.Materialization.Shaper.ErrorHandlingValueReader`1.GetValue(DbDataReader reader, Int32 ordinal)
at System.Data.Common.Internal.Materialization.Shaper.GetPropertyValueWithErrorHandling[TProperty](Int32 ordinal, String propertyName, String typeName)
at lambda_method(Closure , Shaper)
at System.Data.Common.Internal.Materialization.Shaper.HandleEntityAppendOnly[TEntity](Func`2 constructEntityDelegate, EntityKey entityKey, EntitySet entitySet)
at lambda_method(Closure , Shaper)
at System.Data.Common.Internal.Materialization.Coordinator`1.ReadNextElement(Shaper shaper)
at System.Data.Common.Internal.Materialization.Shaper`1.SimpleEnumerator.MoveNext()
at System.Linq.Enumerable.First[TSource](IEnumerable`1 source)
at System.Linq.Queryable.First[TSource](IQueryable`1 source)
at OnlineSelfService.Business.ContentServiceBusiness.GetPageContent(Int32 pageId)</StackTrace>
的實際示例代碼:
//Caller
public EmployeeEntity GetEmployeeDetail(int employeeID)
{
IQueryable<Employee> result=null;
if (myCaching.Contains("Employee"))
{
result = (IQueryable<Employee>)myCaching["Employee"];
}
else
{
result = dataAccess.GetEmployeeDetail();
myCaching.AddToCache("Employee", result); //Expire in 2min
}
IQueryable<Employee> entityResult = from entity in result
where entity.employeeId == employeeID
select entity;
if (entityResult.Count<Employee>() > 0)
return entityResult.First<Employee>();
return new EmployeeEntity();
}
}
//DAL
public IQueryable<Employee> GetEmployeeDetail()
{
DatabaseEntities ent = new DatabaseEntities(this._connectionString);
IQueryable<Employee> result = from employee in ent.EmployeeEntity
select employee;
return result;
}
更新** 更新了我的代碼緩存。
我使用Google搜索並找到答案,但找不到明確答案的根本原因。一些遇到這個問題的人可以分享一個解決方案嗎?
謝謝。
你的上下文是否與數據庫不同步? (數據庫列與類屬性不匹配?) –
問題只是隨機發生的,我不懷疑它是同步問題。 –
相關:http://stackoverflow.com/questions/12617639/weird-random-exceptions –