From ce4d01d96b7e41cf61b8ee3ab4018e15e01dc872 Mon Sep 17 00:00:00 2001 From: Tom Lane <tgl@sss.pgh.pa.us> Date: Sun, 23 Dec 2001 20:22:49 +0000 Subject: [PATCH] Update description of CURRENT_TIMESTAMP and friends. --- doc/src/sgml/func.sgml | 57 ++++++++++++++++++++++++++---------------- 1 file changed, 36 insertions(+), 21 deletions(-) diff --git a/doc/src/sgml/func.sgml b/doc/src/sgml/func.sgml index 5e55381bf62..c9af36d5506 100644 --- a/doc/src/sgml/func.sgml +++ b/doc/src/sgml/func.sgml @@ -1,5 +1,5 @@ <!-- -$Header: /cvsroot/pgsql/doc/src/sgml/func.sgml,v 1.87 2001/12/01 04:19:20 tgl Exp $ +$Header: /cvsroot/pgsql/doc/src/sgml/func.sgml,v 1.88 2001/12/23 20:22:49 tgl Exp $ PostgreSQL documentation --> @@ -2732,7 +2732,7 @@ PostgreSQL documentation <row> <entry><function>timeofday()</function></entry> <entry><type>text</type></entry> - <entry>High-precision date and time; see also <link + <entry>Current date and time; see <link linkend="functions-datetime-current">below</link> </entry> <entry><literal>timeofday()</literal></entry> @@ -3208,25 +3208,50 @@ SELECT date_trunc('year', TIMESTAMP '2001-02-16 20:38:40'); The following functions are available to obtain the current date and/or time: <synopsis> -CURRENT_TIME CURRENT_DATE +CURRENT_TIME CURRENT_TIMESTAMP +CURRENT_TIME ( <replaceable>precision</> ) +CURRENT_TIMESTAMP ( <replaceable>precision</> ) </synopsis> - Note that because of the requirements of the - <acronym>SQL</acronym> standard, these functions must not be - called with trailing parentheses. + <function>CURRENT_TIME</function> and + <function>CURRENT_TIMESTAMP</function> can optionally be given + a precision parameter, which causes the result to be rounded + to that many fractional digits. Without a precision parameter, + the result is given to full available precision. </para> + <note> + <para> + Prior to <productname>PostgreSQL</> 7.2, the precision parameters + were unimplemented, and the result was always given in integer + seconds. + </para> + </note> + + <note> + <para> + The <acronym>SQL99</acronym> standard requires these functions to + be written without any parentheses, unless a precision parameter + is given. As of <productname>PostgreSQL</> 7.2, an empty pair of + parentheses can be written, but this is deprecated and may be + removed in a future release. + </para> + </note> + <informalexample> <screen> SELECT CURRENT_TIME; -<computeroutput>19:07:32</computeroutput> +<computeroutput>14:39:53.662522-05</computeroutput> SELECT CURRENT_DATE; -<computeroutput>2001-02-17</computeroutput> +<computeroutput>2001-12-23</computeroutput> SELECT CURRENT_TIMESTAMP; -<computeroutput>2001-02-17 19:07:32-05</computeroutput> +<computeroutput>2001-12-23 14:39:53.662522-05</computeroutput> + +SELECT CURRENT_TIMESTAMP(2); +<computeroutput>2001-12-23 14:39:53.66-05</computeroutput> </screen> </informalexample> @@ -3237,9 +3262,8 @@ SELECT CURRENT_TIMESTAMP; </para> <para> - There is also <function>timeofday()</function>, which returns current - time to higher precision than the <function>CURRENT_TIMESTAMP</function> - family does: + There is also <function>timeofday()</function>, which for historical + reasons returns a text string rather than a <type>timestamp</type> value: </para> <informalexample> @@ -3249,15 +3273,6 @@ SELECT timeofday(); </screen> </informalexample> - <para> - <function>timeofday()</function> uses the operating system call - <function>gettimeofday(2)</function>, which may have resolution as - good as microseconds (depending on your platform); the other functions - rely on <function>time(2)</function> which is restricted to one-second - resolution. For historical reasons, <function>timeofday()</function> - returns its result as a text string rather than a <type>timestamp</type> value. - </para> - <para> It is quite important to realize that <function>CURRENT_TIMESTAMP</function> and related functions all return -- GitLab