mirror of
https://github.com/postgres/postgres.git
synced 2025-05-03 22:24:49 +03:00
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
This commit is contained in:
parent
aae4097b08
commit
3f898c986e
@ -2103,7 +2103,7 @@ January 8 04:05:06 1999 PST
|
|||||||
</para>
|
</para>
|
||||||
</sect3>
|
</sect3>
|
||||||
|
|
||||||
<sect3>
|
<sect3 id="datatype-datetime-special-values">
|
||||||
<title>Special Values</title>
|
<title>Special Values</title>
|
||||||
|
|
||||||
<indexterm>
|
<indexterm>
|
||||||
@ -2191,12 +2191,26 @@ January 8 04:05:06 1999 PST
|
|||||||
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</> recognized in data input strings.
|
SQL functions and are <emphasis>not</> 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>
|
||||||
|
|
||||||
|
@ -8221,20 +8221,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</>
|
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>
|
||||||
|
Loading…
x
Reference in New Issue
Block a user