Tarih/saat verilerini çıkarma ve dönüştürme

PostgreSQL'de Veriyi İşlemek için Fonksiyonlar

Brian Piccolo

Sr. Director, Digital Strategy

Tarih ve saat verilerini çıkarma ve dönüştürme

EXTRACT(), DATE_PART() ve DATE_TRUNC() işlevlerini keşfetme

  • İşlemsel zaman damgası hassasiyeti analiz için yararlı değil
2005-05-13 08:53:53
  • Zaman damgalarının parçalarını çıkarmak gerekir
2005 veya 5 veya 2 veya Cuma
  • Ya da standartlaştırmak için zaman damgasını dönüştürme/kırpma
2005-05-13 00:00:00
PostgreSQL'de Veriyi İşlemek için Fonksiyonlar

Tarih/saat verilerini çıkarma ve dönüştürme

  • 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       |
+---------+
PostgreSQL'de Veriyi İşlemek için Fonksiyonlar

Zaman damgasından alt alanlar çıkarma

DVD Kiralama sistemindeki payment tablosundan işlemsel veriler

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  |
+--------------------------------------------------------------------------------+
PostgreSQL'de Veriyi İşlemek için Fonksiyonlar

Zaman damgasından alt alanlar çıkarma

payment tablosundan yıl ve çeyreğe göre veriler

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;

Sonuçlar

+---------------------------------+
| quarter | year | total_payments |
|---------|------|----------------|
| 2       | 2005 | 14456.31       |
| 3       | 2005 | 52446.02       |
| 1       | 2006 | 514.18         |
+---------------------------------+
PostgreSQL'de Veriyi İşlemek için Fonksiyonlar

DATE_TRUNC() ile zaman damgalarını kırpma

DATE_TRUNC() işlevi zaman damgası veya aralık veri türlerini kırpar.

  • '2005-05-21 15:30:30' zaman damgasını yıla göre kırpma
SELECT DATE_TRUNC('year', TIMESTAMP '2005-05-21 15:30:30');
Sonuç: 2005-01-01 00:00:00
  • '2005-05-21 15:30:30' zaman damgasını aya göre kırpma
SELECT DATE_TRUNC('month', TIMESTAMP '2005-05-21 15:30:30');
Sonuç: 2005-05-01 00:00:00
PostgreSQL'de Veriyi İşlemek için Fonksiyonlar

Haydi pratik yapalım!

PostgreSQL'de Veriyi İşlemek için Fonksiyonlar

Preparing Video For Download...