Analisis Deret Waktu di PostgreSQL
Jasmin Ludolf
Content Developer, DataCamp
TIMESTAMP: tanggal-waktu tanpa zona waktu
TIMESTAMPTZ: tanggal-waktu dengan 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 savingSHOW TIMEZONE;
|TimeZone |
|---------------|
|Europe/Brussels|
datetimes memiliki dua field berikut:datetime: TIMESTAMPdatetimetz: TIMESTAMPTZINSERT 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|
pg_typeof(field_name): memeriksa tipe data fieldSELECT
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|
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|
AT TIME ZONE: Menambah, mengubah, atau menghapus info zona waktuTIMESTAMP ke TIMESTAMPTZ dan sebaliknyaMenambahkan 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
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