Heim >Java >javaLernprogramm >## Warum wird mein Spring Data JPA @Query-Update nicht in der Entität widergespiegelt?
Keine Aktualisierung mit Spring Data JPA @Query
In Spring Data JPA kann die bereitgestellte Aktualisierungsabfrage die Entität nicht aktualisieren, was zu einem führt Testfehler.
Obwohl die erforderlichen Änderungen an der Abfrage vorgenommen wurden, um parametrisierte Werte zu verwenden, bleiben die aktualisierten Felder unberührt und behalten ihre Anfangswerte. Auch das Hinzufügen eines Flush-Vorgangs unmittelbar vor dem Suchvorgang löst das Problem nicht.
Beim Untersuchen der generierten SQL-Anweisung stellen Sie fest, dass die Aktualisierungsabfrage korrekt ausgeführt wurde, die Abfrage, die die geänderte Entität abruft, jedoch korrekt ausgeführt wird ignoriert. Dies deutet auf ein potenzielles Caching-Problem hin.
Beim Hinzufügen von Aufrufen zu anderen Findern werden die aktualisierten Werte jedoch in den abgerufenen Objekten widergespiegelt. Dieses Verhalten ist inkonsistent und unerwartet.
Außerdem enthält die SQL-Anweisung, die die geänderte Entität abruft, eine Limit-2-Klausel, obwohl davon ausgegangen wird, dass Spring Data immer eine Limit-1-Klausel verwenden sollte, wenn ein einzelnes Objekt zurückgegeben wird.
Interessanterweise funktioniert die Logik beim manuellen Ausführen der generierten SQL-Anweisungen in einem MySQL-Client einwandfrei, was die Frage aufwirft, warum sich dieses Verhalten nicht konsistent auf der Java-Ebene widerspiegelt.
Die Hauptursache für dieses Problem liegt im Standardverhalten des EntityManagers, der Änderungen nicht automatisch löscht. Um das Problem zu beheben, sollte die Option „clearAutomatically“ in der Annotation „@Modifying“ aktiviert werden, um sicherzustellen, dass Änderungen sofort nach der Aktualisierungsabfrage gelöscht werden.
Das obige ist der detaillierte Inhalt von## Warum wird mein Spring Data JPA @Query-Update nicht in der Entität widergespiegelt?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!