Mewakili waktu sipil (atau terkadang waktu fisik).
Jenis ini dapat merepresentasikan waktu sipil dengan salah satu dari beberapa kemungkinan cara:
- Jika utcOffset disetel dan timeZone tidak disetel: waktu sipil pada hari kalender dengan selisih tertentu dari UTC.
- Jika timeZone disetel dan utcOffset tidak disetel: waktu sipil pada hari kalender dalam zona waktu tertentu.
- Jika timeZone maupun utcOffset tidak disetel: waktu sipil pada hari kalender dalam waktu lokal.
Tanggal ini terkait dengan Kalender Gregorius Proleptik.
Jika tahun, bulan, atau hari adalah 0, DateTime dianggap tidak memiliki tahun, bulan, atau hari tertentu.
Jenis ini juga dapat digunakan untuk merepresentasikan waktu fisik jika semua kolom tanggal dan waktu ditetapkan dan salah satu kasus oneof time_offset ditetapkan. Sebaiknya gunakan pesan Timestamp untuk waktu fisik. Jika kasus penggunaan Anda juga ingin menyimpan zona waktu pengguna, hal itu dapat dilakukan di kolom lain.
Jenis ini lebih fleksibel daripada yang mungkin diinginkan beberapa aplikasi. Pastikan untuk mendokumentasikan dan memvalidasi batasan aplikasi Anda.
| Representasi JSON |
|---|
{ "year": integer, "month": integer, "day": integer, "hours": integer, "minutes": integer, "seconds": integer, "nanos": integer, // Union field |
| Kolom | |
|---|---|
year |
Opsional. Tahun dalam hari. Harus dari 1 hingga 9999, atau 0 jika menentukan tanggal dan waktu tanpa tahun. |
month |
Opsional. Bulan. Harus dari 1 hingga 12, atau 0 jika menentukan tanggal dan waktu tanpa bulan. |
day |
Opsional. Hari dalam bulan. Harus dari 1 hingga 31 dan berlaku untuk tahun dan bulan, atau 0 jika menentukan tanggal dan waktu tanpa hari. |
hours |
Opsional. Jam dalam format 24 jam. Harus dari 0 hingga 23, defaultnya adalah 0 (tengah malam). API dapat memilih untuk mengizinkan nilai "24:00:00" untuk skenario seperti waktu tutup bisnis. |
minutes |
Opsional. Menit dalam jam. Harus antara 0 hingga 59, defaultnya adalah 0. |
seconds |
Opsional. Detik menit dari waktu. Biasanya harus berkisar antara 0 sampai 59, default-nya adalah 0. API dapat mengizinkan nilai 60 jika memungkinkan lompatan-detik. |
nanos |
Opsional. Pecahan detik dalam nanodetik. Harus dari 0 hingga 999.999.999, default-nya adalah 0. |
Kolom union time_offset. Opsional. Menentukan offset UTC atau zona waktu DateTime. Pilih salah satu dengan cermat, dengan mempertimbangkan bahwa data zona waktu dapat berubah di masa mendatang (misalnya, suatu negara mengubah tanggal mulai/akhir DST, dan DateTime di masa mendatang dalam rentang yang terpengaruh telah disimpan). Jika tidak diisi, DateTime dianggap dalam waktu lokal. time_offset hanya dapat berupa salah satu dari berikut: |
|
utcOffset |
Selisih waktu UTC. Harus berupa detik penuh, antara -18 jam dan +18 jam. Misalnya, selisih waktu UTC -4:00 akan ditampilkan sebagai { seconds: -14400 }. Durasi dalam detik dengan maksimal sembilan digit pecahan, yang diakhiri dengan ' |
timeZone |
Zona waktu. |