Could we cleanly convert 'now' to now()?  I assume not because we pass
the string to the date code, and have no way to pass back a function
(now()).

Having now and now() behave differently certainly is strange.

CURRENT_TIMESTAMP works fine, but it does because it isn't in quotes. 
Strangely, CURRENT_TIMESTAMP converts to 'now', not now().  Is that a
problem?

            | CURRENT_TIMESTAMP
                {
                    /*
                     * Translate as "'now'::text::timestamptz".
                     * See comments for CURRENT_DATE.
                     */
                    A_Const *s = makeNode(A_Const);
                    TypeName *d;

                    s->val.type = T_String;
                    s->val.val.str = "now";
                    s->typename = SystemTypeName("text");

                    d = SystemTypeName("timestamptz");
                    /* SQL99 mandates a default precision of 6 for timestamp.
                     * Also, that is about as precise as we will get since
                     * we are using a microsecond time interface.
                     * - thomas 2001-12-07
                     */
                    d->typmod = 6;

                    $$ = (Node *)makeTypeCast((Node *)s, d);
                }
 

---------------------------------------------------------------------------

Tom Lane wrote:
> Denis Zaitsev <[EMAIL PROTECTED]> writes:
> > On Sat, Jul 26, 2003 at 10:31:44AM -0400, Tom Lane wrote:
> >> That's a dangerous way to define the default --- 'now' is taken as a
> >> literal of type timestamp, which means it will be reduced to a timestamp
> >> constant as soon as a statement that requires the default is planned.
> 
> > Aaa...  So, the INSERT inside a trigger will use the 'now' for the
> > time this trigger is compiled (i.e. called first time)?  Do I
> > understand right?  And the only outer trigger uses the right 'now' as
> > its value goes from the top-level INSERT...
> 
> Right.
> 
> I put up a proposal in pgsql-hackers to change this behavior:
> http://archives.postgresql.org/pgsql-hackers/2003-07/msg00818.php
> If we made that change then the "wrong" way of defining the default
> would fail in an obvious fashion --- the 'now' would get reduced to a
> particular time immediately at CREATE TABLE.  Doubtless this would annoy
> some people, but the "right" way of defining the default isn't really
> any harder, and it would save folks from getting burnt in corner cases,
> like you were.
> 
> Any comments?
> 
>                       regards, tom lane
> 
> ---------------------------(end of broadcast)---------------------------
> TIP 1: subscribe and unsubscribe commands go to [EMAIL PROTECTED]
> 

-- 
  Bruce Momjian                        |  http://candle.pha.pa.us
  [EMAIL PROTECTED]               |  (610) 359-1001
  +  If your life is a hard drive,     |  13 Roberts Road
  +  Christ can be your backup.        |  Newtown Square, Pennsylvania 19073

---------------------------(end of broadcast)---------------------------
TIP 9: the planner will ignore your desire to choose an index scan if your
      joining column's datatypes do not match

Reply via email to