Rumah >Java >javaTutorial >Bagaimanakah API `java.time` Java dan Jenis `DATE` MySQL Boleh Mengendalikan Tarikh Tanpa Maklumat Masa atau Zon Waktu?

Bagaimanakah API `java.time` Java dan Jenis `DATE` MySQL Boleh Mengendalikan Tarikh Tanpa Maklumat Masa atau Zon Waktu?

Barbara Streisand
Barbara Streisandasal
2024-12-29 14:33:11428semak imbas

How Can Java's `java.time` API and MySQL's `DATE` Type Handle Dates Without Time or Timezone Information?

Tarikh Tanpa Masa atau Zon Waktu dalam Java/MySQL

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

  • The Pangkalan data MySQL secara dalaman menyimpan nilai DATE dalam UTC, tetapi ia dipaparkan dalam zon waktu pelanggan apabila ditanya.
  • Pemandu JDBC mengendalikan penukaran yang diperlukan antara UTC dan zon waktu setempat semasa interaksi pangkalan data.

Faedah

  • Memastikan perwakilan tarikh yang konsisten merentas zon waktu yang berbeza.
  • Menghapuskan keperluan untuk zon waktu yang kompleks pengiraan atau manipulasi rentetan.
  • Memudahkan reka bentuk skema pangkalan data dan operasi pengambilan data.

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!

Kenyataan:
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