Rumah > Java > javaTutorial > Mengapa Kemas Kini JPA @Query Data Spring Saya Tidak Berfungsi: EntityManager Flush Mystery?

Mengapa Kemas Kini JPA @Query Data Spring Saya Tidak Berfungsi: EntityManager Flush Mystery?

Linda Hamilton
Lepaskan: 2024-10-27 07:10:29
asal
286 orang telah melayarinya

Why Does My Spring Data JPA @Query Update Not Work: The EntityManager Flush Mystery?

Kemas Kini JPA Data Musim Bunga @Query Tidak Mengemas kini: Dilema Flush

Apabila menggunakan anotasi @Query untuk operasi kemas kini dalam Spring Data JPA, ia adalah penting untuk memahami tingkah laku EntityManager. Secara lalai, EntityManager tidak secara automatik membuang perubahan pada pangkalan data. Ini boleh membawa kepada hasil yang tidak dijangka, di mana kemas kini kelihatan diabaikan.

Dalam kes kod yang diberikan, ujian penyepaduan gagal kerana perubahan yang dibuat pada entiti Pentadbir tidak dibuang ke pangkalan data selepas pertanyaan kemas kini . Untuk menyelesaikan isu ini, adalah disyorkan untuk menggunakan pilihan clearAutomatically = true dengan anotasi @Modifying:

@Modifying(clearAutomatically = true)
@Transactional
@Query("UPDATE Admin SET firstname = :firstname, lastname = :lastname, login = :login, superAdmin = :superAdmin, preferenceAdmin = :preferenceAdmin, address =  :address, zipCode = :zipCode, city = :city, country = :country, email = :email, profile = :profile, postLoginUrl = :postLoginUrl WHERE id = :id")
public void update(@Param("firstname") String firstname, @Param("lastname") String lastname, ...);
Salin selepas log masuk

Dengan menambahkan pilihan ini, EntityManager akan secara automatik mengepam perubahan selepas pertanyaan kemas kini dilaksanakan, memastikan bahawa mereka diteruskan ke pangkalan data.

Pemerhatian Tambahan:

  • Klausa had 2 yang dilihat dalam pernyataan SQL untuk pencari findByEmail dan findByLogin ialah pangkalan data- tingkah laku tertentu apabila menggunakan klausa mengehadkan dengan pertanyaan WHERE IN. Spring Data menggunakan gelagat ini untuk mengoptimumkan pertanyaan berdasarkan maklumat yang diperolehi.
  • Perbezaan antara gelagat dalam MySQL dan Java mungkin berkaitan dengan penggunaan pemacu JDBC atau tetapan sambungan yang berbeza. Memastikan ketekalan antara tetapan pemacu dan sambungan yang digunakan dalam kedua-dua persekitaran adalah penting.

Atas ialah kandungan terperinci Mengapa Kemas Kini JPA @Query Data Spring Saya Tidak Berfungsi: EntityManager Flush Mystery?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan