Rumah >Java >javaTutorial >Bagaimanakah API `java.time` Java dan Jenis `DATE` MySQL Boleh Mengendalikan Tarikh Tanpa Maklumat Masa atau Zon Waktu?
Pengenalan
Menyimpan tarikh yang mewakili hanya tahun, bulan, dan hari, seperti hari lahir, menimbulkan cabaran dalam mengendalikan zon waktu. Artikel ini meneroka penyelesaian yang elegan untuk masalah ini menggunakan API Java moden.
Cabaran
Perwakilan masa tarikh Java tradisional (cth., java.util.Date) sertakan kedua-dua komponen zon masa dan masa. Menyimpan tarikh abstrak yang tidak mempunyai masa atau zon waktu tertentu menimbulkan kebimbangan tentang mengekalkan konsistensi merentas persekitaran yang berbeza dengan zon waktu yang berbeza-beza.
Penyelesaian: java.time
Java SE 8 memperkenalkan API java.time, yang menyediakan cara yang mantap dan cekap untuk mengendalikan pengiraan tarikh-masa. LocalDate ialah kelas utama dalam API ini, mewakili tarikh tanpa sebarang maklumat masa atau zon waktu.
Contohnya:
LocalDate birthday = LocalDate.of(1990, 1, 1);
Kod ini mewakili hari lahir 1 Januari 1990, tanpa mengira zon waktu mesin.
Memetakan ke MySQL
LocalDate memetakan kepada ANSI SQL jenis DATE, seperti yang ditunjukkan di bawah:
ALTER TABLE persons ADD COLUMN birthday DATE;
Pertimbangan Pangkalan Data
Faedah
Contoh
Pertimbangkan kod Java berikut yang menyimpan a tarikh lahir dalam pangkalan data MySQL:
// Store a birthday in UTC: String query = "INSERT INTO persons (birthday) VALUES (?)"; PreparedStatement statement = connection.prepareStatement(query); statement.setObject(1, birthday); // Retrieve birth date from database in UTC: String query = "SELECT birthday FROM persons WHERE id = ?"; PreparedStatement statement = connection.prepareStatement(query); statement.setInt(1, personId); ResultSet resultSet = statement.executeQuery(); LocalDate birthday = resultSet.getObject("birthday", LocalDate.class);
Kod ini memastikan bahawa hari lahir disimpan dan diambil semula sebagai nilai tarikh tulen, tanpa sebarang maklumat masa atau zon waktu.
Atas ialah kandungan terperinci Bagaimanakah API `java.time` Java dan Jenis `DATE` MySQL Boleh Mengendalikan Tarikh Tanpa Maklumat Masa atau Zon Waktu?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!