问题:
在创建订单时,postgres自动设置的时间now()不正确,经常使用以前的时间
问题排查:
线索:now()作为默认值时,在同一个transaction里面多次调用是一样的;所以我怀疑是不是用了以前一个未结束的事务来处理了本次请求;
查看链接:
select count(*) from pg_stat_activity where datname='dbname';
select usename,state from pg_stat_activity where datname='dbname';
查看锁:
select count(*) form pg_locks;
流程:
> select usename,state from pg_stat_activity where datname='dbname';
显示的state都是idle in transaction
当执行一次创建订单时;其中一个变为idle;
当执行一个获取信息时;又变成了idle in transaction
我怀疑这里有问题;用了上一次idle的事务,导致使用了上一次开始事务的时间;
果然如此:代码中“获取信息”时有2处没有commit
idle in transaction时什么意思:(事务未结束???)
https://*.com/questions/51019/what-does-it-mean-when-a-postgresql-process-is-idle-in-transaction
https://www.postgresql.org/message-id/20080617133250.GA68434@commandprompt.com