发现了 PG 的一个问题,就是当我在一个 function 中记录不同的 now()的时候,实际上这些 now()是同一个值。案例如下:
--创建日志表 create table dw_sp_log ( log_no serial, log_time varchar(60), schema_nm varchar(60), proc_nm varchar(60), log_level varchar(60), log_msg text ); --创建日志存储过程 create or replace function SP_CM_GEN_LOG( in vc_log_time varchar, in vc_schema varchar, in vc_proc varchar, in vc_level varchar, in vc_msg text ) returns void as $$ declare begin insert into dw_sp_log(log_time,schema_nm, proc_nm, log_level, log_msg) values(vc_log_time,vc_schema,vc_proc,vc_level,vc_msg); end; $$ language plpgsql; --在存储过程中记录日志 create or replace function RUN_SP_CM_GEN_LOG( ) returns void as $$ declare begin perform SP_CM_GEN_LOG(now()::text,'1','1','1','1'); perform pg_sleep(5); perform SP_CM_GEN_LOG(now()::text,'2','2','2','2'); end; $$ language plpgsql;
执行 select RUN_SP_CM_GEN_LOG()会发现里面记录的 log_time 是相同的。但是实际上应该差 5 秒才对,请问如何实现呢?谢谢大家
![]() | 1 xjmroot 2019-11-27 17:53:39 +08:00 ![]() 试试 clock_timestamp()::TEXT |
![]() | 2 zjp 2019-11-27 18:44:05 +08:00 via Android ![]() now(): Current date and time (start of current transaction) clock_timestamp()才是当前时刻 https://www.postgresql.org/docs/8.2/functions-datetime.html#FUNCTIONS-DATETIME-CURRENT |
3 heavyrainn OP 非常感谢二位~ |