From: Bruce Momjian Date: Sun, 24 Jun 2018 03:32:41 +0000 (-0400) Subject: doc: show how interval's 3 unit buckets behave using EXTRACT() X-Git-Tag: REL9_3_24~31 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=1d4b73cdddd43cbdeddb48b3cf7d96add7919a66;p=postgresql doc: show how interval's 3 unit buckets behave using EXTRACT() This clarifies when justify_days() and justify_hours() are useful. Paragraph moved too. Reported-by: vodevsh@gmail.com Discussion: https://postgr.es/m/152698651482.26744.15456677499485530703@wrigleys.postgresql.org Backpatch-through: 9.3 --- diff --git a/doc/src/sgml/datatype.sgml b/doc/src/sgml/datatype.sgml index aaee81ca37..be9b868285 100644 --- a/doc/src/sgml/datatype.sgml +++ b/doc/src/sgml/datatype.sgml @@ -2657,19 +2657,6 @@ P years-months-days < to each field if any field is negative. - - Internally interval values are stored as months, days, - and seconds. This is done because the number of days in a month - varies, and a day can have 23 or 25 hours if a daylight savings - time adjustment is involved. The months and days fields are integers - while the seconds field can store fractions. Because intervals are - usually created from constant strings or timestamp subtraction, - this storage method works well in most cases. Functions - justify_days and justify_hours are - available for adjusting days and hours that overflow their normal - ranges. - - In the verbose input format, and in some fields of the more compact input formats, field values can have fractional parts; for example @@ -2721,6 +2708,33 @@ P years-months-days < + + Internally interval values are stored as months, days, + and seconds. This is done because the number of days in a month + varies, and a day can have 23 or 25 hours if a daylight savings + time adjustment is involved. The months and days fields are integers + while the seconds field can store fractions. Because intervals are + usually created from constant strings or timestamp subtraction, + this storage method works well in most cases, but can cause unexpected + results: + + +SELECT EXTRACT(hours from '80 minutes'::interval); + date_part +----------- + 1 + +SELECT EXTRACT(days from '80 hours'::interval); + date_part +----------- + 0 + + + Functions justify_days and + justify_hours are available for adjusting days + and hours that overflow their normal ranges. + +