叫我用EF 4.0和它的作品真的很好,当异常,但问题发生时 我打电话查询:LINQ到实体,ToList()从非UI线程
var query = from employee in employees from cr in employee.RcpCrossRegister select new { employee, cr }
然后当我打电话
var list = query.ToList()
我得到异常
Collection was modified; enumeration operation may not execute
and call stack:
w System.ThrowHelper.ThrowInvalidOperationException(ExceptionResource resource)
w System.Collections.Generic.List`1.Enumerator.MoveNextRare()
w System.Collections.Generic.List`1.Enumerator.MoveNext()
w System.Data.Objects.DataClasses.EntityCollection`1.CheckIfNavigationPropertyContainsEntity(IEntityWrapper wrapper)
w System.Data.Objects.DataClasses.RelatedEnd.Add(IEntityWrapper wrappedTarget, Boolean applyConstraints, Boolean addRelationshipAsUnchanged, Boolean relationshipAlreadyExists, Boolean allowModifyingOtherEndOfRelationship, Boolean forceForeignKeyChanges)
w System.Data.Objects.DataClasses.RelatedEnd.Add(IEntityWrapper wrappedEntity, Boolean applyConstraints)
w System.Data.Objects.DataClasses.EntityReference`1.set_ReferenceValue(IEntityWrapper value)
w System.Data.Objects.DataClasses.EntityReference.SetEntityKey(EntityKey value, Boolean forceFixup)
w System.Data.Objects.EntityEntry.FixupEntityReferenceToPrincipal(EntityReference relatedEnd, EntityKey foreignKey, Boolean setIsLoaded, Boolean replaceExistingRef)
w System.Data.Objects.EntityEntry.FixupReferencesByForeignKeys(Boolean replaceAddedRefs)
w System.Data.Objects.ObjectStateManager.FixupReferencesByForeignKeys(EntityEntry newEntry, Boolean replaceAddedRefs)
w System.Data.Objects.ObjectStateManager.AddEntry(IEntityWrapper wrappedObject, EntityKey passedKey, EntitySet entitySet, String argumentName, Boolean isAdded)
w System.Data.Common.Internal.Materialization.Shaper.HandleEntityAppendOnly[TEntity](Func`2 constructEntityDelegate, EntityKey entityKey, EntitySet entitySet)
w lambda_method(Closure , Shaper)
w System.Data.Common.Internal.Materialization.Coordinator`1.ReadNextElement(Shaper shaper)
w System.Data.Common.Internal.Materialization.Shaper`1.SimpleEnumerator.MoveNext()
w TCS.bos.Infrastructure.Data.MainModule.Repositories.EmployeeRepository.GetEmployeesEvacuationTimeSheet(Int64 dateHour)
w TCS.bos.Domain.MainModule.Employees.EmployeeTimeSheetService.GetEmployeesEvacuationTimeSheet(Int64 dateHour)
w TCS.plg.TimeSheets.ViewModels.TimeSheetsGridViewModel.GetAll2()
w TCS.plg.TimeSheets.ViewModels.TimeSheetsGridViewModel.<>c__DisplayClass4.<FilterCommand>b__2()
w TCS.Core.Caliburn.Invocation.BackgroundTask.<>c__DisplayClassd.<.ctor>b__4(Object s, DoWorkEventArgs e) w D:\VS2010\CaliburnMicro\caliburnmicro_a63379fba70a\TCS.2.3\TCS.Core\Caliburn\Invocation\BackgroundTask.cs:wiersz 41
w System.ComponentModel.BackgroundWorker.OnDoWork(DoWorkEventArgs e)
w System.ComponentModel.BackgroundWorker.WorkerThreadStart(Object argument)
你在创建查询和枚举它之间做了什么?这是推迟的,所以你以前做的任何事情都不会发生,直到你试图枚举。 – 2011-04-20 08:28:50
你是对的,但这正是我使用的代码... – Robertok 2011-04-20 08:34:17