Rumah >pangkalan data >tutorial mysql >Bagaimana untuk Membetulkan Ralat \'Nilai Zon Masa Pelayan \'AEST\' Tidak Diiktiraf\' dalam Hibernate?
Membetulkan "Nilai Zon Masa Pelayan 'AEST' Tidak Diiktiraf" Isu dalam Hibernate
Ralat "Nilai zon masa pelayan 'AEST ' tidak dikenali atau mewakili lebih daripada satu zon waktu" berlaku apabila MySQL tidak dapat mengenali zon waktu pelayan dan pemacu JDBC tidak mempunyai konfigurasi zon waktu yang jelas. Untuk menyelesaikan isu ini:
1. Tentukan Zon Masa Pelayan dalam URL Sambungan:
Tambah parameter zon Waktu pelayan pada URL sambungan JDBC anda. Parameter ini menentukan zon waktu yang MySQL harus gunakan. Dalam kes ini, anda boleh menetapkan zon waktu kepada 'UTC' atau 'Australia/Melbourne' berdasarkan zon waktu lalai yang dicetak oleh System.out.println(TimeZone.getDefault()).
jdbc:mysql://localhost:3306/database?serverTimezone=UTC
2. Konfigurasikan Zon Waktu pelayan dalam Sifat Hibernate:
Dalam fail konfigurasi Hibernate anda (biasanya hibernate.cfg.xml), tambahkan sifat berikut:
<property name="hibernate.connection.serverTimezone">UTC</property>
3. Naik taraf MySQL Connector:
Jika anda menggunakan versi lama MySQL Connector, ia mungkin tidak menyokong pengurusan zon waktu sepenuhnya. Cuba tingkatkan kepada versi yang lebih baharu (cth., 8.0 atau lebih tinggi) untuk keserasian yang lebih baik.
4. Pastikan Zon Masa Pelayan Diiktiraf:
Pastikan zon waktu yang dinyatakan dalam parameter zon waktu pelayan dikenali dan disokong oleh pelayan MySQL. Sahkan ini dengan melaksanakan pertanyaan berikut dalam MySQL:
SELECT * FROM mysql.time_zone WHERE name = 'UTC';
5. Dayakan Sokongan Zon Waktu JDBC:
Dalam kes yang jarang berlaku, pemacu JDBC mungkin memerlukan konfigurasi tambahan untuk menyokong sepenuhnya zon waktu. Rujuk dokumentasi pemandu (cth., [MySQL Connector J](https://dev.mysql.com/doc/connector-j/en/connector-j-reference-configuration-properties.html)) untuk arahan khusus.
Nota: Biasanya disyorkan untuk menggunakan zon waktu tertentu (cth., 'UTC') dan bukannya dipendekkan atau samar-samar (mis., 'AEST') untuk mengelakkan potensi isu seperti peralihan masa penjimatan siang.
Atas ialah kandungan terperinci Bagaimana untuk Membetulkan Ralat \'Nilai Zon Masa Pelayan \'AEST\' Tidak Diiktiraf\' dalam Hibernate?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!