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://stackoverflow.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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值