8.7. Data Type Formatting Functions

The EnterpriseDB formatting functions provide a powerful set of tools for converting various data types (date/time, integer, floating point, numeric) to formatted strings and for converting from formatted strings to specific data types. Table 8-19 lists them. These functions all follow a common calling convention: the first argument is the value to be formatted and the second argument is a template that defines the output or input format.

Table 8-19. Formatting Functions

FunctionReturn TypeDescriptionExample
to_char(DATE, VARCHAR)VARCHARconvert a value of DATE datatype to VARCHAR datatypeto_char(sysdate, 'HH12:MI:SS')
to_char(INT, VARCHAR)VARCHARconvert INTEGER to VARCHARto_char(125, '999')
to_char(DOUBLE PRECISION, VARCHAR)VARCHARconvert REAL/DOUBLE PRECISION to VARCHARto_char(125.8::real, '999D9')
to_char(NUMERIC, VARCHAR)VARCHARconvert >NUMERIC to VARCHARto_char(-125.8, '999D99S')
to_date(VARCHAR, VARCHAR)DATEconvert VARCHAR to DATEto_date('05 Dec 2000', 'DD Mon YYYY')
to_timestamp(VARCHAR, VARCHAR)TIMESTAMPconvert VARCHAR to TIME STAMPto_timestamp('05 Dec 2000', 'DD Mon YYYY')
to_number(VARCHAR, VARCHAR)NUMERICconvert VARCHAR to NUMERICto_number('12,454.8-', '99G999D9S')

In an output template string (for to_char), there are certain patterns that are recognized and replaced with appropriately-formatted data from the value to be formatted. Any text that is not a template pattern is simply copied verbatim. Similarly, in an input template string (for anything but to_char), template patterns identify the parts of the input data string to be looked at and the values to be found there.

Table 8-20 shows the template patterns available for formatting datetime values using the to_char and to_date functions.

Table 8-20. Template Date/Time Format Patterns for the to_char and to_date Functions

PatternDescription
ADAD indicator without periods.
A.D.AD indicator with periods.
AMMeridian indicator without periods.
A.M.Meridian indicator with periods.
BCBC indicator without periods.
B.C.BC indicator with periods.
CCOne greater than the first two digits of a four-digit year;
SCCOne greater than the first two digits of a four-digit year; "S" prefixes BC dates with "-"
DDay of week (1-7).
DAYName of day, padded with blanks to length of 9 characters.
DDDay of month (1-31).
DDDDay of year (1-366).
DYAbbreviated name of day.
EAbbreviated era name (Japanese Imperial, ROC Official, and Thai Buddha calendars).
EEFull era name (Japanese Imperial, ROC Official, and Thai Buddha calendars).
FF [1..9]

Fractional seconds; no radix character is printed (use the X format element to add the radix character). Use the numbers 1 to 9 after FF to specify the number of digits in the fractional second portion of the datetime value returned. If you do not specify a digit, then EnterpriseDB uses the precision specified for the datetime datatype or the datatype's default precision.

Example

                 SELECT TO_CHAR(SYSTIMESTAMP, 'SS.FF3') FROM DUAL;
                 

HHHour of day (1-12).
HH12Hour of day (1-12).
HH24Hour of day (0-23).
IWWeek of year (1-52 or 1-53) based on the ISO standard.
IYY IY I Last 3, 2, or 1 digit(s) of ISO year.
IYYY4-digit year based on the ISO standard.
JJulian day; the number of days since January 1, 4712 BC. Number specified with "J" must be integers.
MIMinute (0-59).
MMMonth (01-12; JAN = 01).
MONAbbreviated name of month.
MONTHName of month, padded with blanks to length of 9 characters.
PMMeridian indicator without periods.
P.M.Meridian indicator with periods.
QQuarter of year (1, 2, 3, 4; JAN-MAR = 1).
RMRoman numeral month (I-XII; JAN = I).
RR

Given a year with 2 digits:

  • If the year is <50 and the last 2 digits of the current year are >=50, then the first 2 digits of the returned year are 1 greater than the first 2 digits of the current year.

  • If the year is >=50 and the last 2 digits of the current year are <50, then the first 2 digits of the returned year are 1 less than the first 2 digits of the current year.

RRRRRound year. Accepts either 4-digit or 2-digit input. If 2-digit, provides the same return as RR. If you don't want this functionality, then simply enter the 4-digit year.
SSSecond (0-59).
SSSSSSeconds past midnight (0-86399).
TZD

Daylight savings information. The TZD value is an abbreviated time zone string with daylight savings information. It must correspond with the region specified in TZR.

Examples:

                 PST (for US/Pacific standard time); PDT (for US/Pacific daylight time).
              

TZHTime zone hour.
TZMTime zone minute.
TZRTime zone region information. The value must be one of the time zone regions supported in the database.
WWWeek of year (1-53) where week 1 starts on the first day of the year and continues to the seventh day of the year.
WWeek of month (1-5) where week 1 starts on the first day of the month and ends on the seventh.
XLocal radix character.
Y,YYYYear with comma in this position.
YEARYear, spelled out
SYEARYear, spelled out; "S" prefixes BC dates with "-".
YYYY4-digit year
SYYYY4-digit year
YYY YY Y Last 3, 2, or 1 digit(s) of year.

Certain modifiers may be applied to any template pattern to alter its behavior. For example, FMMonth is the Month pattern with the FM modifier. Table 8-21 shows the modifier patterns for date/time formatting.

Table 8-21. Template Pattern Modifiers for Date/Time Formatting

ModifierDescriptionExample
FM prefixfill mode (suppress padding blanks and zeroes)FMMonth
TH suffixuppercase ordinal number suffixDDTH
th suffixlowercase ordinal number suffixDDth
FX prefixfixed format global option (see usage notes)FX Month DD Day
SP suffixspell mode (not yet implemented)DDSP

Usage notes for the date/time formatting:

Table 8-22 shows the template patterns available for formatting numeric values.

Table 8-22. Template Patterns for Numeric Formatting

PatternDescription
9value with the specified number of digits with a leading space if positive or with a leading minus if negative.
0value with leading/trailing zeros
$value with a leading dollar sign
MIplaces a trailing minus sign (-) with a negative value
Dspecifies the location of a decimal point in the returned value
Gspecifies the location of the group separator in the returned value
Lcurrency symbol (uses locale)
Ddecimal point (uses locale)
, (comma)returns a comma in the specified position.
. (period)returns a decimal point, which is a period (.) in the specified position

Usage notes for the numeric formatting:

Table 8-23 shows some examples of the use of the to_char and to_date functions.

Table 8-23. to_char and to_date function Examples

ExpressionResult
to_char(current_timestamp, 'Day, DD  HH12:MI:SS')'Tuesday  , 06  05:39:18'
to_char(-0.1, '99.99')'  -.10'
to_char(-0.1, 'FM9.99')'-.1'
to_char(0.1, '0.9')' 0.1'
to_char(12, '9990999.9')'    0012.0'
to_char(12, 'FM9990999.9')'0012.'
to_char(485, '999')' 485'
to_char(-485, '999')'-485'
to_char(1485, '9,999')' 1,485'
to_char(148.5, '999.999')' 148.500'
to_char(148.5, 'FM999.999')'148.5'
to_char(148.5, 'FM999.990')'148.500'
to_char(-485, '999S')'485-'
to_char(-485, '999MI')'485-'
to_char(485, '999MI')'485 '
to_char(485, 'FM999MI')'485'
to_char(485, 'L999')'$         485
to_char(485, 'RN')'        CDLXXXV'
to_char(485, 'FMRN')'CDLXXXV'
to_char(5.2, 'FMRN')'V'
to_char(12, '99V999')' 12000'
to_char(12.4, '99V999')' 12400'
to_char(12.45, '99V9')' 125'
to_number(0, '99.9')'.00'
to_number(-0.2, '99.9')'-.20'