代码改变世界

PostgreSQL事务中的时间

  abce  阅读(527)  评论(0编辑  收藏  举报

在同一个事务中,时间是不变的:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
postgres=# begin;
BEGIN
postgres=# select now(),current_time,current_timestamp,localtime,localtimestamp,transaction_timestamp();
              now              |    current_time    |       current_timestamp       |    localtime    |       localtimestamp       |     transaction_timestamp    
-------------------------------+--------------------+-------------------------------+-----------------+----------------------------+-------------------------------
 2021-01-22 16:50:46.917081+08 | 16:50:46.917081+08 | 2021-01-22 16:50:46.917081+08 | 16:50:46.917081 | 2021-01-22 16:50:46.917081 | 2021-01-22 16:50:46.917081+08
(1 row)
 
postgres=# select pg_sleep_for('10 seconds');
 pg_sleep_for
--------------
  
(1 row)
 
postgres=# select now(),current_time,current_timestamp,localtime,localtimestamp,transaction_timestamp();
              now              |    current_time    |       current_timestamp       |    localtime    |       localtimestamp       |     transaction_timestamp    
-------------------------------+--------------------+-------------------------------+-----------------+----------------------------+-------------------------------
 2021-01-22 16:50:46.917081+08 | 16:50:46.917081+08 | 2021-01-22 16:50:46.917081+08 | 16:50:46.917081 | 2021-01-22 16:50:46.917081 | 2021-01-22 16:50:46.917081+08
(1 row)
 
postgres=#

 

要想获得在事务中某个语句执行的时间,可以使用clock_timestamp()

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
postgres=# begin;
BEGIN
postgres=# select statement_timestamp(),clock_timestamp();
      statement_timestamp      |        clock_timestamp       
-------------------------------+-------------------------------
 2021-01-22 16:54:13.433445+08 | 2021-01-22 16:54:13.433605+08
(1 row)
 
postgres=# select pg_sleep_for('10 seconds');
 pg_sleep_for
--------------
  
(1 row)
 
postgres=# select statement_timestamp(),clock_timestamp();
     statement_timestamp      |        clock_timestamp       
------------------------------+-------------------------------
 2021-01-22 16:54:29.92086+08 | 2021-01-22 16:54:29.921041+08
(1 row)
 
postgres=#

  

编辑推荐:
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· .NET10 - 预览版1新功能体验(一)
历史上的今天:
2016-01-22 SQL Performance Analyzer
点击右上角即可分享
微信分享提示