Menyatakan waktu sipil (atau terkadang waktu fisik).
Jenis ini dapat merepresentasikan waktu sipil dengan salah satu dari beberapa kemungkinan:
- Jika utcOffset ditetapkan dan timeZone tidak ditetapkan: waktu sipil pada hari kalender dengan selisih tertentu dari UTC.
- Jika timeZone ditetapkan dan utcOffset tidak ditetapkan: waktu sipil pada hari kalender di zona waktu tertentu.
- Jika timeZone atau utcOffset tidak ditetapkan: waktu sipil pada hari kalender dalam waktu lokal.
Tanggal tersebut 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 mewakili waktu fisik jika semua kolom tanggal dan waktu ditetapkan dan salah satu kasus time_offset
disetel. Pertimbangkan untuk menggunakan pesan Timestamp
bagi waktu fisik. Jika kasus penggunaan Anda juga ingin menyimpan zona waktu pengguna, hal tersebut dapat dilakukan di kolom lain.
Jenis ini lebih fleksibel daripada yang mungkin diinginkan oleh 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. Harus dari 1 hingga 9999, atau 0 jika menentukan tanggal/waktu tanpa tahun. |
month |
Opsional. Bulan. Harus dari 1 hingga 12, atau 0 jika menentukan tanggal dan waktu tanpa bulan. |
day |
Opsional. Tanggal. Harus dari 1 hingga 31 dan valid 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 sehari. Harus dari 0 hingga 59, setelan defaultnya adalah 0. |
seconds |
Opsional. Detik menit dalam waktu. Biasanya harus dari 0 hingga 59, default-nya adalah 0. API dapat mengizinkan nilai 60 jika mengizinkan detik kabisat. |
nanos |
Opsional. Pecahan detik dalam nanodetik. Harus dari 0 hingga 999.999.999, default-nya adalah 0. |
Kolom union time_offset . Opsional. Menentukan selisih UTC atau zona waktu DateTime. Pilih dengan cermat di antara keduanya, dengan mempertimbangkan bahwa data zona waktu dapat berubah di masa mendatang (misalnya, negara mengubah tanggal mulai/akhir DST, dan DateTime yang akan datang dalam rentang yang terpengaruh telah disimpan). Jika dihapus, DateTime dianggap berada dalam waktu lokal. time_offset hanya dapat berupa salah satu dari berikut: |
|
utcOffset |
Offset UTC. Harus dalam hitungan detik, antara -18 jam dan +18 jam. Misalnya, offset UTC -4:00 akan direpresentasikan sebagai { seconds: -14400 }. Durasi dalam detik dengan maksimal sembilan digit pecahan, yang diakhiri dengan ' |
timeZone |
Zona waktu. |
TimeZone
Merepresentasikan zona waktu dari Database Zona Waktu IANA.
Representasi JSON |
---|
{ "id": string, "version": string } |
Kolom | |
---|---|
id |
Zona waktu Database Zona Waktu IANA, mis. "America/New_York". |
version |
Opsional. Nomor versi Database Zona Waktu IANA, mis., "2019a". |