Commit 54084981 authored by Tom Lane's avatar Tom Lane

Doc: caution against misuse of 'now' and related datetime literals.

Section 8.5.1.4, which defines these literals, made only a vague
reference to the fact that they might be evaluated too soon to be
safe in non-interactive contexts.  Provide a more explicit caution
against misuse.  Also, generalize the wording in the related tip in
section 9.9.4: while it clearly described this problem, it implied
(or really, stated outright) that the problem only applies to table
DEFAULT clauses.

Per gripe from Tijs van Dam.  Back-patch to all supported branches.

Discussion: https://postgr.es/m/c2LuRv9BiRT3bqIo5mMQiVraEXey_25B4vUn0kDqVqilwOEu_iVF1tbtvLnyQK7yDG3PFaz_GxLLPil2SDkj1MCObNRVaac-7j1dVdFERk8=@thalex.com
parent c4a803ac
...@@ -2197,7 +2197,7 @@ TIMESTAMP WITH TIME ZONE '2004-10-19 10:23:54+02' ...@@ -2197,7 +2197,7 @@ TIMESTAMP WITH TIME ZONE '2004-10-19 10:23:54+02'
</para> </para>
</sect3> </sect3>
<sect3> <sect3 id="datatype-datetime-special-values">
<title>Special Values</title> <title>Special Values</title>
<indexterm> <indexterm>
...@@ -2285,12 +2285,26 @@ TIMESTAMP WITH TIME ZONE '2004-10-19 10:23:54+02' ...@@ -2285,12 +2285,26 @@ TIMESTAMP WITH TIME ZONE '2004-10-19 10:23:54+02'
type: type:
<literal>CURRENT_DATE</literal>, <literal>CURRENT_TIME</literal>, <literal>CURRENT_DATE</literal>, <literal>CURRENT_TIME</literal>,
<literal>CURRENT_TIMESTAMP</literal>, <literal>LOCALTIME</literal>, <literal>CURRENT_TIMESTAMP</literal>, <literal>LOCALTIME</literal>,
<literal>LOCALTIMESTAMP</literal>. The latter four accept an <literal>LOCALTIMESTAMP</literal>. (See <xref
optional subsecond precision specification. (See <xref
linkend="functions-datetime-current"/>.) Note that these are linkend="functions-datetime-current"/>.) Note that these are
SQL functions and are <emphasis>not</emphasis> recognized in data input strings. SQL functions and are <emphasis>not</emphasis> recognized in data input strings.
</para> </para>
<caution>
<para>
While the input strings <literal>now</literal>,
<literal>today</literal>, <literal>tomorrow</literal>,
and <literal>yesterday</literal> are fine to use in interactive SQL
commands, they can have surprising behavior when the command is
saved to be executed later, for example in prepared statements,
views, and function definitions. The string can be converted to a
specific time value that continues to be used long after it becomes
stale. Use one of the SQL functions instead in such contexts.
For example, <literal>CURRENT_DATE + 1</literal> is safer than
<literal>'tomorrow'::date</literal>.
</para>
</caution>
</sect3> </sect3>
</sect2> </sect2>
......
...@@ -10044,20 +10044,22 @@ now() ...@@ -10044,20 +10044,22 @@ now()
<programlisting> <programlisting>
SELECT CURRENT_TIMESTAMP; SELECT CURRENT_TIMESTAMP;
SELECT now(); SELECT now();
SELECT TIMESTAMP 'now'; -- incorrect for use with DEFAULT SELECT TIMESTAMP 'now'; -- but see tip below
</programlisting> </programlisting>
</para> </para>
<tip> <tip>
<para> <para>
You do not want to use the third form when specifying a <literal>DEFAULT</literal> Do not use the third form when specifying a value to be evaluated later,
clause while creating a table. The system will convert <literal>now</literal> for example in a <literal>DEFAULT</literal> clause for a table column.
The system will convert <literal>now</literal>
to a <type>timestamp</type> as soon as the constant is parsed, so that when to a <type>timestamp</type> as soon as the constant is parsed, so that when
the default value is needed, the default value is needed,
the time of the table creation would be used! The first two the time of the table creation would be used! The first two
forms will not be evaluated until the default value is used, forms will not be evaluated until the default value is used,
because they are function calls. Thus they will give the desired because they are function calls. Thus they will give the desired
behavior of defaulting to the time of row insertion. behavior of defaulting to the time of row insertion.
(See also <xref linkend="datatype-datetime-special-values"/>.)
</para> </para>
</tip> </tip>
</sect2> </sect2>
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment