Entitätsaktualisierungen mit Definierungsabfragefehler
Beim Versuch, Entitäten in Entity Framework 1 zu aktualisieren, kann ein Fehler auftreten, wenn der Zielentitätssatz dies getan hat eine DefiningQuery, aber es fehlt eine Element in seinem . Diese Fehlermeldung weist auf Folgendes hin:
Unable to update the EntitySet - because it has a DefiningQuery and no <UpdateFunction> element exists in the <ModificationFunctionMapping> element to support the current operation.
Mögliche Ursachen
Der Fehler tritt normalerweise aus einem der folgenden Gründe auf:
-
Datenbankansichtszuordnung: Der Entitätssatz wird einer Datenbank zugeordnet Ansicht.
-
Benutzerdefinierte Datenbankabfragen: Eine benutzerdefinierte Datenbankabfrage wird verwendet, um den Entitätssatz zu generieren.
-
Fehlender Primärschlüssel: Die zugrunde liegende Datenbanktabelle Der Entität fehlt ein Primärelement Schlüssel.
Auflösung
-
Überprüfen Sie die Entitätssatzzuordnung: Stellen Sie sicher, dass der Entitätssatz korrekt zugeordnet ist. Wenn es einer Ansicht oder einer benutzerdefinierten Abfrage zugeordnet ist, wird eine Das Element muss im bereitgestellt werden. um Updates zu unterstützen.
-
Primärschlüssel überprüfen: Bestätigen Sie, dass die mit der Entität verknüpfte Datenbanktabelle über einen Primärschlüssel verfügt. Wenn nicht, fügen Sie eine zur Tabelle hinzu.
-
Entity Framework Designer aktualisieren: Nach der Korrektur der Zuordnung oder Tabellenstruktur müssen Sie möglicherweise den Entity Framework Designer aktualisieren oder die Entität neu erstellen, um das Problem zu beheben .
Hinweis: Durch einfaches Löschen und erneutes Hinzufügen der Entität kann das Problem ebenfalls gelöst werden, ist aber wichtig um die zugrunde liegende Ursache anzugehen und ein erneutes Auftreten zu verhindern.
Das obige ist der detaillierte Inhalt vonWarum wirft Entity Framework bei DefiningQuery den Fehler „EntitySet konnte nicht aktualisiert werden' aus?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!
Stellungnahme:Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn