TO_CHAR

Converts a value of type DATE, TIMESTAMP, or TIMESTAMPTZ to a formatted string.

Syntax

TO_CHAR(<expression>, '<format>')

Parameters

Parameter Description Supported input types
<expression> A date or time expression to be converted to text. DATE, TIMESTAMP, TIMESTAMPTZ
<format> A string literal that specifies the format of the <expression> to convert. See below.

Accepted <format> patterns include:

Format option Description Example  
HH12 or HH Hour of day (01–12) TO_CHAR(TIMESTAMPTZ '2023-03-03 18:24:58.085109', 'hh12 HH'); --> '06 06'  
HH24 Hour of day (00–23) TO_CHAR(TIMESTAMPTZ '2023-03-03 18:24:58.085109', 'HH24'); --> '18'  
MI Minute (00–59) TO_CHAR(TIMESTAMPTZ '2023-03-03 18:24:58.085109', 'MI'); --> '24'  
SS Second (00–59) TO_CHAR(TIMESTAMPTZ '2023-03-03 18:24:58.085109', 'SS'); --> '58'  
SSSS or SSSSS Seconds past midnight (0–86399) TO_CHAR(TIMESTAMPTZ '2023-03-03 18:24:58.085109', 'SSSS'); --> '41098'  
MS Millisecond (000–999) TO_CHAR(TIMESTAMPTZ '2023-03-03 18:24:58.085109', 'MS'); --> '085'  
US Microsecond (000000–999999) TO_CHAR(TIMESTAMPTZ '2023-03-03 18:24:58.085109', 'US'); --> '085109'  
Y,YYY Year (4 or more digits) with comma Y,YYY TO_CHAR(TIMESTAMPTZ '2023-03-03 18:24:58.085109', 'Y,YYY'); --> '2,023'  
YYYY Year (4 or more digits) TO_CHAR(TIMESTAMPTZ '2023-03-03 18:24:58.085109', 'YYYY'); --> '2023'  
YYY Last 3 digits of year TO_CHAR(TIMESTAMPTZ '2023-03-03 18:24:58.085109', 'YYY'); --> '023'  
YY Last 2 digits of year TO_CHAR(TIMESTAMPTZ '2023-03-03 18:24:58.085109', 'YY'); --> '23'  
Y Last digit of year TO_CHAR(TIMESTAMPTZ '2023-03-03 18:24:58.085109', 'Y'); --> '3'  
IYYY ISO 8601 week-numbering year (4 or more digits) TO_CHAR(TIMESTAMPTZ '2023-03-03 18:24:58.085109', 'IYYY'); --> '2023'  
IYY Last 3 digits of ISO 8601 week-numbering year TO_CHAR(TIMESTAMPTZ '2023-03-03 18:24:58.085109', 'IYY'); --> '023'  
IY Last 2 digits of ISO 8601 TO_CHAR(TIMESTAMPTZ '2023-03-03 18:24:58.085109', 'IY'); --> '23'  
I Last digit of ISO 8601 week-numbering year TO_CHAR(TIMESTAMPTZ '2023-03-03 18:24:58.085109', 'I'); --> '3'  
MM Month number (01–12) TO_CHAR(TIMESTAMPTZ '2023-03-03 18:24:58.085109', 'MM'); --> '03'  
DDD Day of year (001–366) TO_CHAR(TIMESTAMPTZ '2023-03-03 18:24:58.085109', 'DDD'); --> '062'  
DD Day of month (01–31) TO_CHAR(TIMESTAMPTZ '2023-03-03 18:24:58.085109', 'DD'); --> '03'  
D Day of the week, Sunday (1) to Saturday (7) TO_CHAR(TIMESTAMPTZ '2023-03-03 18:24:58.085109', 'D'); --> '6'  
ID ISO 8601 day of the week, Monday (1) to Sunday (7) TO_CHAR(TIMESTAMPTZ '2023-03-03 18:24:58.085109', 'ID'); --> '5'  
W Week of month (1–5) (the first week starts on the first day of the month) TO_CHAR(TIMESTAMPTZ '2023-03-03 18:24:58.085109', 'W'); --> '1'  
WW Week number of year (1–53) (the first week starts on the first day of the year) TO_CHAR(TIMESTAMPTZ '2023-03-03 18:24:58.085109', 'WW'); --> '09'  
IW Week number of ISO 8601 week-numbering year (01–53) (the first Thursday of the year is in week 1) TO_CHAR(TIMESTAMPTZ '2023-03-03 18:24:58.085109', 'IW'); --> '09'  
CC Century (2 digits) (the twenty-first century starts on 2001-01-01) TO_CHAR(TIMESTAMPTZ '2023-03-03 18:24:58.085109', 'CC'); --> '21'  
Q Single digit quarter TO_CHAR(TIMESTAMPTZ '2023-03-03 18:24:58.085109', 'Q'); --> '1'  
AM or PM Meridiem indicator upper case without periods TO_CHAR(TIMESTAMPTZ '2023-03-03 18:24:58.085109', 'hhAM'); --> '6PM'  
am or pm Meridiem indicator lower case without periods TO_CHAR(TIMESTAMPTZ '2023-03-03 09:24:58', 'hhpm'); --> '9am'  
A.M. or P.M. Meridiem indicator upper case with periods TO_CHAR(TIMESTAMPTZ '2023-03-03 18:24:58', 'hhP.M.'); --> '6P.M.'  
a.m. or p.m. Meridiem indicator lower case with periods TO_CHAR(TIMESTAMPTZ '2023-03-03 09:24:58', 'hha.m.'); --> '9a.m.'  
MONTH Full upper case month name (blank-padded to 9 chars) TO_CHAR(DATE '2023-03-03', 'MONTH'); --> 'MARCH    '
Month Full capitalized month name (blank-padded to 9 chars) TO_CHAR(DATE '2023-08-07', 'Month'); --> 'August   '  
month Full lower case month name (blank-padded to 9 chars) TO_CHAR(DATE '2023-09-10', 'month'); --> 'September'  
MON Abbreviated upper case month name (3 chars) TO_CHAR(DATE '2023-07-03', 'MON'); --> 'JUL'  
Mon Abbreviated capitalized month name (3 chars) TO_CHAR(DATE '2023-01-03', 'Mon'); --> 'Jan'  
mon Abbreviated lower case month name (3 chars) TO_CHAR(DATE '2023-12-03', 'mon'); --> 'dec'  
DAY Full upper case day name (blank-padded to 9 chars) TO_CHAR(DATE '2023-03-07', 'DAY'); --> 'TUESDAY  '  
Day Full capitalized day name (blank-padded to 9 chars) TO_CHAR(DATE '2023-03-08', 'Day'); --> 'Wednesday'  
day Full lower case day name (blank-padded to 9 chars) TO_CHAR(DATE '2023-03-09', 'day'); --> 'thursday '  
DY Abbreviated upper case day name (3 chars in English) TO_CHAR(DATE '2023-03-09', 'DY'); --> 'THU'  
Dy Abbreviated capitalized day name (3 chars in English) TO_CHAR(DATE '2023-03-10', 'Dy'); --> 'Fri'  
dy Abbreviated lower case day name (3 chars in English) TO_CHAR(DATE '2023-03-11', 'dy'); --> 'sat'  
RM Month in upper case Roman numerals (I–XII; I=January) TO_CHAR(DATE '2023-03-03', 'RM'); --> 'III'  
rm Month in lower case Roman numerals (i–xii; i=January) TO_CHAR(DATE '2023-06-03', 'rm'); --> 'vi'  
AD or BC Upper case era indicator without periods TO_CHAR(DATE '2023-03-03', 'BC'); --> 'AD'  
ad or bc lower case era indicator without periods TO_CHAR(DATE '2023-03-03', 'ad'); --> 'ad'  
A.D. or B.C. Upper case era indicator with periods TO_CHAR(DATE '2023-03-03', 'A.D.'); --> 'A.D.'  
a.d. or b.c. Upper case era indicator with periods TO_CHAR(DATE '2023-03-03', 'b.c.'); --> 'a.d.'  
TZ Upper case time-zone abbreviation SET timezone = 'America/Vancouver';
TO_CHAR(TIMESTAMPTZ '2023-03-03', 'TZ'); --> 'PST'
 
tz Lower case time-zone abbreviation SET timezone = 'Europe/Berlin';
TO_CHAR(TIMESTAMPTZ '2023-03-03', 'tz'); --> 'cet'
 
TZH Time zone hours SET TIMEZONE = 'Israel';
TO_CHAR(TIMESTAMPTZ '2023-03-03', 'TZH'); --> '+02'
 
TZM Time zone minutes SET TIMEZONE = 'Israel';
TO_CHAR(TIMESTAMPTZ '2023-03-03', 'tzm'); --> '00'
 
OF Time zone offset from UTC SET TIMEZONE = 'America/New_York';
TO_CHAR(TIMESTAMPTZ '2023-03-03', 'OF'); --> '-08:00'
 

Additionally, modifiers can be applied to the format patterns above to alter their behavior.

Format option Description Example
FM prefix Surpress leading zeroes and padding blanks TO_CHAR(CURRENT_DATE, 'Month YYYY'); --> 'March     2023'
TO_CHAR(CURRENT_DATE, 'FMMonth YYYY'); --> 'March 2023'
TH suffix Upper case ordinal number suffix TO_CHAR(CURRENT_TIMESTAMP, 'MMTH'); --> '1ST'
th suffix Lower case ordinal number suffix TO_CHAR(CURRENT_TIMESTAMP, 'MMth'); --> '3rd'

Any character in the format string that is not recognized as a pattern is simply copied over without being replaced. Parts that are quoted " will be copied over independent of possibly valid patterns. Patterns are matched in lower and upper case if there is no other behavior described above.

Return Types

Formatted string based on the function’s specifications

Examples

The example below outputs the current local time in a formatted string. Note that the " around the words Date and Time are required, otherwise the characters D and I would be interpreted as valid patterns which would result in the output 6ate and T3me.

SELECT
    TO_CHAR(
        TIMESTAMPTZ '2023-03-02 06:33:26.466511',
        '"Date": FMMonth FMddth, YYYY "Time": FMHH12am (mi:ss.us) OF (TZ)'
    );

Returns

'Date: March 2nd, 2023 Time: 6am (33:26.466511) -08:00 (PST)'

Example

The following example outputs the current date in a formatted string with any time field set to 0 which indicates midnight. Note the quotation marks again that are required to prevent unintended replacements:

SELECT
    TO_CHAR(
        DATE '2023-03-02' ,
        '"The" fmDDDth "day in" YY "is a" fmDay "at midnight" hh24:mi:ss.us'
    );

Returns

'The 61st day in 23 is a Thursday at midnight 00:00:00.000000'