DATE_PART function
DATE_PART extracts date part values from an expression. DATE_PART is a synonym of the PGDATE_PART function.
Syntax
DATE_PART(datepart, {date|timestamp})
Arguments
- datepart
-
An identifier literal or string of the specific part of the date value (for example, year, month, or day) that the function operates on. For more information, see Date parts for date or timestamp functions.
- {date|timestamp}
-
A date column, timestamp column, or an expression that implicitly converts to a date or timestamp. The column or expression in date or timestamp must contain the date part specified in datepart.
Return type
DOUBLE
Examples
The default column name for the DATE_PART function is
pgdate_part
.
The following example finds the minute from a timestamp literal.
SELECT DATE_PART(minute, timestamp '20230104 04:05:06.789');
pgdate_part ----------- 5
The following example finds the week number from a timestamp literal. The week number
calculation follows the ISO 8601 standard. For more information, see ISO 8601
SELECT DATE_PART(week, timestamp '20220502 04:05:06.789');
pgdate_part ----------- 18
The following example finds the day of the month from a timestamp literal.
SELECT DATE_PART(day, timestamp '20220502 04:05:06.789');
pgdate_part ----------- 2
The following example finds the day of the week from a timestamp literal. The week
number calculation follows the ISO 8601 standard. For more information, see ISO 8601
SELECT DATE_PART(dayofweek, timestamp '20220502 04:05:06.789');
pgdate_part ----------- 1
The following example finds the century from a timestamp literal. The century
calculation follows the ISO 8601 standard. For more information, see ISO 8601
SELECT DATE_PART(century, timestamp '20220502 04:05:06.789');
pgdate_part ----------- 21
The following example finds the millennium from a timestamp literal. The millennium
calculation follows the ISO 8601 standard. For more information, see ISO 8601
SELECT DATE_PART(millennium, timestamp '20220502 04:05:06.789');
pgdate_part ----------- 3
The following example finds the microseconds from a timestamp literal. The
microseconds calculation follows the ISO 8601 standard. For more information, see ISO 8601
SELECT DATE_PART(microsecond, timestamp '20220502 04:05:06.789');
pgdate_part ----------- 789000
The following example finds the month from a date literal.
SELECT DATE_PART(month, date '20220502');
pgdate_part ----------- 5
The following example applies the DATE_PART function to a column in a table.
SELECT date_part(w, listtime) AS weeks, listtime FROM listing WHERE listid=10
weeks | listtime ------+--------------------- 25 | 2008-06-17 09:44:54 (1 row)
You can name date parts in full or abbreviate them; in this case, w stands for weeks.
The day of week date part returns an integer from 0-6, starting with Sunday. Use DATE_PART with dow (DAYOFWEEK) to view events on a Saturday.
SELECT date_part(dow, starttime) AS dow, starttime FROM event WHERE date_part(dow, starttime)=6 ORDER BY 2,1;
dow | starttime -----+--------------------- 6 | 2008-01-05 14:00:00 6 | 2008-01-05 14:00:00 6 | 2008-01-05 14:00:00 6 | 2008-01-05 14:00:00 ... (1147 rows)