Bekerja dengan informasi zona waktu

Analisis Deret Waktu di PostgreSQL

Jasmin Ludolf

Content Developer, DataCamp

Data zona waktu

  • TIMESTAMP: tanggal-waktu tanpa zona waktu

    • Cukup jika hanya satu zona waktu
    • Semua waktu dalam UTC
  • TIMESTAMPTZ: tanggal-waktu dengan zona waktu

Ilustrasi empat jam dengan waktu berbeda.

Analisis Deret Waktu di PostgreSQL

Nama zona waktu

SELECT * FROM pg_timezone_names;
| name             |abbrev|utc_offset|is_dst|
|------------------|------|----------|------|
|Africa/Abidjan    |GMT   |  00:00:00|false |
|Africa/Accra      |GMT   |  00:00:00|false |
|Africa/Addis_Ababa|EAT   |   3:00:00|false |
...
  • is_dst: apakah lokasi menerapkan daylight saving
Analisis Deret Waktu di PostgreSQL

Tampilkan zona waktu

SHOW TIMEZONE;
|TimeZone       |
|---------------|
|Europe/Brussels|
Analisis Deret Waktu di PostgreSQL

Data zona waktu di tabel

  • Tabel datetimes memiliki dua field berikut:
    • datetime: TIMESTAMP
    • datetimetz: TIMESTAMPTZ
INSERT INTO datetimes (datetime, datetimetz)
VALUES('2023-01-03 12:00:00','2023-01-03 12:00:00');
|datetime           |datetimetz               |
|-------------------|-------------------------|
|2023-01-03 12:00:00|2023-01-03 12:00:00+01:00|
Analisis Deret Waktu di PostgreSQL

Verifikasi tipe data

  • pg_typeof(field_name): memeriksa tipe data field
SELECT
    pg_typeof(datetime) AS "type of(datetime)", 
    pg_typeof(datetimetz) AS "type of(datetimetz)"
FROM datetimes;
|type of(datetime)          |type of(datetimetz)     |
|---------------------------|------------------------|
|timestamp without time zone|timestamp with time zone|
Analisis Deret Waktu di PostgreSQL

Menggunakan informasi zona waktu

INSERT INTO datetimes (datetime, datetimetz)
VALUES('2023-01-03 12:00:00+00','2023-01-03 12:00:00+00');
SELECT * FROM datetimes;
|datetime           |datetimetz               |
|-------------------|-------------------------|
|2023-01-03 12:00:00|2023-01-03 12:00:00+01:00|
|2023-01-03 12:00:00|2023-01-03 13:00:00+01:00|
Analisis Deret Waktu di PostgreSQL

Menambahkan informasi zona waktu

  • AT TIME ZONE: Menambah, mengubah, atau menghapus info zona waktu
    • Mengonversi tipe dari TIMESTAMP ke TIMESTAMPTZ dan sebaliknya

Menambahkan zona waktu:

SELECT 
    TIMESTAMP '2020-12-31 23:59:59' AT TIME ZONE 'Europe/London' AS added;
|added                    |
|-------------------------|
|2021-01-01 00:59:59+01:00|

Kueri ini: menafsirkan timestamp, membuat TIMESTAMPTZ, menampilkan default

Analisis Deret Waktu di PostgreSQL

Mengubah dan menghapus zona waktu

SELECT 
    '2020-12-31 23:59:59+00'::TIMESTAMPTZ AT TIME ZONE 'Europe/Paris' 
    AS shifted;
|shifted            |
|-------------------|
|2021-01-01 00:59:59|

Kueri ini: menggeser timestamp ke zona waktu yang diinginkan, menghapus penanda zona waktu

Analisis Deret Waktu di PostgreSQL

Ayo berlatih!

Analisis Deret Waktu di PostgreSQL

Preparing Video For Download...