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
Lepaskan: 2024-12-29 14:33:11
asal
428 orang telah melayarinya

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);
Salin selepas log masuk

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;
Salin selepas log masuk

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);
Salin selepas log masuk

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!

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