postgres使用now()作为默认值时,出现的时间过期问题

问题:

在创建订单时,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

上一篇:MVC之Model开发(一)


下一篇:STM32一种使用HAL,DMA,IDLE,POLLING的方式来处理UART的不定长接收机制