J'ai une entité LINQ comme ceci:LINQ: IndexOutOfRangeException
ID1 INT
ID2 INT
ID3 INT
Value VARCHAR(50)
ID1, ID2 & ID3 sont les clés primaires composites. Il n'a aucune association avec une autre entité.
Un IndexOutOfRangeException est lancé chaque fois que je mets à jour ou supprimer après SubmitChanges. Je cours sur .NET 3.5 SP1.
J'ai essayé de créer un autre projet, toujours sur .NET 3.5 SP1, mais je ne rencontre pas cette exception.
Voici le code:
DataClasses context = new DataClasses();
Entity entity = (from entities in context.Entities
where entities.ID1 == 3
&& entities.ID2 == 1
&& entities.ID3 == 1
select entities).First();
context.Entities.DeleteOnSubmit(entity);
context.SubmitChanges();
Voici l'exception:
System.IndexOutOfRangeException was unhandled by user code
Message="Index was outside the bounds of the array."
Source="System.Data.Linq"
StackTrace:
at System.Data.Linq.IdentityManager.StandardIdentityManager.MultiKeyManager`3.TryCreateKeyFromValues(Object[] values, MultiKey`2& k)
at System.Data.Linq.IdentityManager.StandardIdentityManager.IdentityCache`2.Find(Object[] keyValues)
at System.Data.Linq.IdentityManager.StandardIdentityManager.Find(MetaType type, Object[] keyValues)
at System.Data.Linq.CommonDataServices.GetCachedObject(MetaType type, Object[] keyValues)
at System.Data.Linq.ChangeProcessor.GetOtherItem(MetaAssociation assoc, Object instance)
at System.Data.Linq.ChangeProcessor.BuildEdgeMaps()
at System.Data.Linq.ChangeProcessor.SubmitChanges(ConflictMode failureMode)
at System.Data.Linq.DataContext.SubmitChanges(ConflictMode failureMode)
at System.Data.Linq.DataContext.SubmitChanges()
at Project.Page.Page_Load(Object sender, EventArgs e) in C:\ProjectFolder\Project\Page.aspx.cs:line 31
at System.Web.Util.CalliHelper.EventArgFunctionCaller(IntPtr fp, Object o, Object t, EventArgs e)
at System.Web.Util.CalliEventHandlerDelegateProxy.Callback(Object sender, EventArgs e)
at System.Web.UI.Control.OnLoad(EventArgs e)
at System.Web.UI.Control.LoadRecursive()
at System.Web.UI.Page.ProcessRequestMain(Boolean includeStagesBeforeAsyncPoint, Boolean includeStagesAfterAsyncPoint)
InnerException:
Y a-t-il un record répondant à vos critères? –
Oui. Il retourne un seul enregistrement. – acermate433s