Fungsi untuk Memanipulasi Data di PostgreSQL
Brian Piccolo
Sr. Director, Digital Strategy
Menjelajahi fungsi EXTRACT(), DATE_PART() dan DATE_TRUNC()
2005-05-13 08:53:53
2005 atau 5 atau 2 atau Friday
2005-05-13 00:00:00
EXTRACT( field FROM source )
SELECT EXTRACT(quarter FROM timestamp '2005-01-24 05:12:00') AS quarter;
DATE_PART('field', source)
SELECT DATE_PART('quarter', timestamp '2005-01-24 05:12:00') AS quarter;
+---------+
| quarter |
|---------|
| 1 |
+---------+
Data transaksional dari tabel payment DVD Rentals
SELECT * FROM payment;
+--------------------------------------------------------------------------------+
| payment_id | customer_id | staff_id | rental_id | amount | payment_date |
|------------|-------------|----------|-----------|--------|---------------------|
| 1 | 1 | 1 | 76 | 2.99 | 2005-05-25 11:30:37 |
| 2 | 1 | 1 | 573 | 0.99 | 2005-05-28 10:35:23 |
| 3 | 1 | 1 | 1185 | 5.99 | 2005-06-15 0:54:12 |
+--------------------------------------------------------------------------------+
Data dari tabel payment per tahun dan kuartal
SELECT
EXTRACT(quarter FROM payment_date) AS quarter,
EXTRACT(year FROM payment_date) AS year,
SUM(amount) AS total_payments
FROM
payment
GROUP BY 1, 2;
Hasil
+---------------------------------+
| quarter | year | total_payments |
|---------|------|----------------|
| 2 | 2005 | 14456.31 |
| 3 | 2005 | 52446.02 |
| 1 | 2006 | 514.18 |
+---------------------------------+
Fungsi DATE_TRUNC() memangkas tipe data timestamp atau interval.
SELECT DATE_TRUNC('year', TIMESTAMP '2005-05-21 15:30:30');
Hasil: 2005-01-01 00:00:00
SELECT DATE_TRUNC('month', TIMESTAMP '2005-05-21 15:30:30');
Hasil: 2005-05-01 00:00:00
Fungsi untuk Memanipulasi Data di PostgreSQL