1
0
mirror of https://github.com/postgres/postgres.git synced 2025-10-24 01:29:19 +03:00

Doc: clarify behavior of timestamptz input some more.

Try to make it absolutely plain that we don't retain the
originally specified time zone, only the UTC timestamp.

While at it, make glossary entries for "UTC" and "GMT".

Author: Robert Treat <rob@xzilla.net>
Co-authored-by: Tom Lane <tgl@sss.pgh.pa.us>
Discussion: https://postgr.es/m/173796426022.1064.9135167366862649513@wrigleys.postgresql.org
Backpatch-through: 13
This commit is contained in:
Tom Lane
2025-02-07 12:40:41 -05:00
parent dc32ba249b
commit fe47f3897e
2 changed files with 30 additions and 11 deletions

View File

@@ -2141,24 +2141,27 @@ TIMESTAMP '2004-10-19 10:23:54+02'
<programlisting> <programlisting>
TIMESTAMP WITH TIME ZONE '2004-10-19 10:23:54+02' TIMESTAMP WITH TIME ZONE '2004-10-19 10:23:54+02'
</programlisting> </programlisting>
In a literal that has been determined to be <type>timestamp without time
zone</type>, <productname>PostgreSQL</productname> will silently ignore
any time zone indication.
That is, the resulting value is derived from the date/time
fields in the input value, and is not adjusted for time zone.
</para> </para>
<para> <para>
For <type>timestamp with time zone</type>, the internally stored In a value that has been determined to be <type>timestamp without time
value is always in UTC (Universal zone</type>, <productname>PostgreSQL</productname> will silently ignore
Coordinated Time, traditionally known as Greenwich Mean Time, any time zone indication.
<acronym>GMT</acronym>). An input value that has an explicit That is, the resulting value is derived from the date/time
time zone specified is converted to UTC using the appropriate offset fields in the input string, and is not adjusted for time zone.
</para>
<para>
For <type>timestamp with time zone</type> values, an input string
that includes an explicit time zone will be converted to UTC
(<glossterm linkend="glossary-utc">Universal Coordinated
Time</glossterm>) using the appropriate offset
for that time zone. If no time zone is stated in the input string, for that time zone. If no time zone is stated in the input string,
then it is assumed to be in the time zone indicated by the system's then it is assumed to be in the time zone indicated by the system's
<xref linkend="guc-timezone"/> parameter, and is converted to UTC using the <xref linkend="guc-timezone"/> parameter, and is converted to UTC using the
offset for the <varname>timezone</varname> zone. offset for the <varname>timezone</varname> zone.
In either case, the value is stored internally as UTC, and the
originally stated or assumed time zone is not retained.
</para> </para>
<para> <para>

View File

@@ -674,6 +674,11 @@
</glossdef> </glossdef>
</glossentry> </glossentry>
<glossentry>
<glossterm>GMT</glossterm>
<glosssee otherterm="glossary-utc" />
</glossentry>
<glossentry id="glossary-grant"> <glossentry id="glossary-grant">
<glossterm>Grant</glossterm> <glossterm>Grant</glossterm>
<glossdef> <glossdef>
@@ -1769,6 +1774,17 @@
</glossdef> </glossdef>
</glossentry> </glossentry>
<glossentry id="glossary-utc">
<glossterm>UTC</glossterm>
<glossdef>
<para>
Universal Coordinated Time, the primary global time reference,
approximately the time prevailing at the zero meridian of longitude.
Often but inaccurately referred to as GMT (Greenwich Mean Time).
</para>
</glossdef>
</glossentry>
<glossentry id="glossary-vacuum"> <glossentry id="glossary-vacuum">
<glossterm>Vacuum</glossterm> <glossterm>Vacuum</glossterm>
<glossdef> <glossdef>