Redshift’e Giriş
Jason Myers
Principal Architect
SYSDATE işlem başlangıcındaki tarih ve saat-- Geçerli tarih ve saati alın
SELECT SYSDATE;
timestamp
============================
2024-01-27 20:05:55.976353
GETDATE() ifade başlangıcındaki tarih ve saat, parantez gerekir-- Geçerli tarih ve saati alın
SELECT GETDATE();
timestamp
============================
2024-01-27 20:06:55.976353
Yalnızca lider düğümde çalışan işlevlere dikkat!
AGE yerine DATEDIFFGETDATE/SYSDATE:CURRENT_TIMECURRENT_TIMESTAMPISFINITELOCALTIMELOCALTIMESTAMPNOWTRUNC bir timestamp'ten tarih döndürür-- 2024-01-27 20:05:55.976353 SYSDATE'ine göre
-- bugünün tarihini alın
SELECT TRUNC(SYSDATE);
2024-01-27
DATE_TRUNC('datepart', timestamp) saat veya gün gibi bir datepart'a kırpar-- 2024-01-27 20:05:55.976353 SYSDATE'ine göre
-- dakikaya kırpın
SELECT DATE_TRUNC('minute', SYSDATE);
2024-01-27 20:05:55
DATE_PART(datepart, date or timestamp) -- 2024-01-27 20:05:55.976353 SYSDATE'ine göre
-- geçerli ayı alın
SELECT DATE_PART(month, SYSDATE);
1
month, day, year dışında da döndürebilirdayofweek, quarter, timezone-- 2024-01-27 20:05:55.976353 SYSDATE'ine göre
-- haftanın gününü alın
SELECT DATE_PART(dayofweek, SYSDATE);
6
DATE_CMP(date_1, date_2) göreli karşılaştırma
Türe özel işlevler
DATE_CMP_TIMESTAMPDATE_CMP_TIMESTAMPTZTIMESTAMP_CMPTIMESTAMP_CMP_TIMESTAMPTZTIMESTAMPTZ_CMP-- 2024-01-27 20:05:55.976353 SYSDATE'ine göre
-- bir tablodaki 5 tarihi karşılaştırın
SELECT date_col,
TRUNC(SYSDATE) AS current_date,
DATE_CMP(date_col, SYSDATE)
FROM combined_history_projections
ORDER BY date_col
LIMIT 3;
date_col | current_date | date_cmp
===========|===============|==========
2024-01-26 | 2024-01-27 | -1
2024-01-27 | 2024-01-27 | 0
2024-01-28 | 2024-01-27 | 1
DATEDIFF(datepart, value_1, value_2)-- İlk çeyrek sonuna gün sayısı,
-- 2024-01-27 20:05:55.976353 SYSDATE'ine göre
SELECT DATEDIFF(day,TRUNC(SYSDATE),'2024-03-31') AS days_diff;
days_diff
===========
64
DATEADD(datepart, quantity, value)-- 2024-01-27 20:05:55.976353 SYSDATE'ine göre
-- bir haftayı tarihe ekleyin
SELECT TRUNC(SYSDATE) AS todays_date,
TRUNC(DATEADD(week, 1, SYSDATE)) AS next_weeks_date;
todays_date | next_weeks_date
============|==================
2024-01-27 | 2024-02-03
-- Bir tarihe ay bazında yıl ekleyin
SELECT DATEADD(month, 12, '2024-02-29');
2025-02-28 00:00:00
-- Bir tarihe yıl bazında yıl ekleyin
SELECT DATEADD(year, 1, '2024-02-29');
2025-03-01 00:00:00
Redshift’e Giriş