Re: Using timestamp in function

Поиск
Список
Период
Сортировка
От Michael Fuhr
Тема Re: Using timestamp in function
Дата
Msg-id 20041005161912.GA55627@winnie.fuhr.org
обсуждение исходный текст
Ответ на Using timestamp in function  (Silke Trissl <trissl@informatik.hu-berlin.de>)
Список pgsql-sql
On Tue, Oct 05, 2004 at 05:37:51PM +0200, Silke Trissl wrote:

> CREATE or replace FUNCTION mylog_test(integer, varchar) RETURNS 
> timestamp AS '
>     DECLARE
>         n ALIAS FOR $1;
>         logtxt ALIAS FOR $2;
>         curtime timestamp;
>     BEGIN
>         curtime := ''now'';
>         --INSERT INTO logger VALUES ( nextval(''seq_log''), curtime, 
> substr(logtxt,0,200));
>         RAISE NOTICE ''TIME: %'',curtime;
>         RETURN curtime;
>     END;
> ' LANGUAGE plpgsql;
> 
> I expected, that the variable curtime gets a new time value, each time 
> the function is called (at least that is what I understood from the 
> documentation). This works fine, if I test it with
> SELECT mylog_test(5, 'test');
> But as soon as I call the funtion from another function (which I need) 
> the variable curtime does not change anymore.

"Functions and trigger procedures are always executed within a
transaction established by an outer query...." [1]

"It is important to know that CURRENT_TIMESTAMP and related functions
return the start time of the current transaction; their values do not
change during the transaction....timeofday() returns the wall-clock
time and does advance during transactions." [2]

[1] http://www.postgresql.org/docs/7.4/static/plpgsql-structure.html
[2] http://www.postgresql.org/docs/7.4/static/functions-datetime.html#FUNCTIONS-DATETIME-CURRENT

-- 
Michael Fuhr
http://www.fuhr.org/~mfuhr/


В списке pgsql-sql по дате отправления:

Предыдущее
От: Tom Lane
Дата:
Сообщение: Re: Using timestamp in function
Следующее
От: "Kent Anderson"
Дата:
Сообщение: Stored Procedures returning a RECORD