PostgreSQL provides all kinds of time-related functions. But time is not as easy as it seems. One question many people keep asking: How can I find the current timestamp? What time is it?
Table of Contents
While this seems like an easy question the answer isn't as clear-cut as you might expect. Basically, there are three functions we might use to figure out what time it is:
Depending on what kind of time you want, different functions have to be called. When writing code, it is important to be aware of those subtle differences to ensure that your program is doing exactly what it's supposed to do:
The most common way to determine time is to ask for “transaction time”. The idea is to have a function which “freezes time” and returns the same value throughout the transaction. The following listing shows an example:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 |
test=# BEGIN; BEGIN test=*# SELECT now(); now ------------------------------- 2023-01-18 13:44:53.654281+01 (1 row) test=*# SELECT now(); now ------------------------------- 2023-01-18 13:44:53.654281+01 (1 row) test=*# SELECT now(); now ------------------------------- 2023-01-18 13:44:53.654281+01 (1 row) test=*# COMMIT; COMMIT |
As you can see, the timestamp is absolutely constant and does not change at all. Often “now” is seen as a default value. Sporadically this can cause bugs, because people expect time to change — which is not so in this case, by design.
In addition to now()
there is also a way to find the timestamp of your current operation. In this case the timestamp will change inside your transaction but not inside your statement. You can rely on the fact that the same result will be returned throughout the entire (top level) operation.
The following listing shows how this works:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 |
test=# BEGIN; BEGIN test=*# SELECT statement_timestamp(), pg_sleep(1), statement_timestamp(); statement_timestamp | pg_sleep | statement_timestamp -------------------------------+----------+------------------------------- 2023-01-18 13:47:37.173645+01 | | 2023-01-18 13:47:37.173645+01 (1 row) test=*# SELECT statement_timestamp(), pg_sleep(1), statement_timestamp(); statement_timestamp | pg_sleep | statement_timestamp -------------------------------+----------+------------------------------- 2023-01-18 13:47:40.213119+01 | | 2023-01-18 13:47:40.213119+01 (1 row) test=*# SELECT statement_timestamp(), pg_sleep(1), statement_timestamp(); statement_timestamp | pg_sleep | statement_timestamp -------------------------------+----------+------------------------------- 2023-01-18 13:47:42.750033+01 | | 2023-01-18 13:47:42.750033+01 (1 row) test=*# COMMIT; COMMIT |
As you can see the pg_sleep() statement does not change the return value of the time function. It merely changes when the next statement starts.
Finally, there is the clock_timestamp()
function which returns the current timestamp. The important thing is that this function will return different values all the time. It does NOT guarantee to return different values but in reality it “almost” does. Here is an example showing how this works:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 |
test=# BEGIN; BEGIN test=*# SELECT clock_timestamp(), pg_sleep(1), clock_timestamp(); clock_timestamp | pg_sleep | clock_timestamp -------------------------------+----------+------------------------------- 2023-01-18 13:48:51.495893+01 | | 2023-01-18 13:48:52.496906+01 (1 row) test=*# SELECT clock_timestamp(), pg_sleep(1), clock_timestamp(); clock_timestamp | pg_sleep | clock_timestamp -------------------------------+----------+------------------------------- 2023-01-18 13:48:53.286361+01 | | 2023-01-18 13:48:54.287368+01 (1 row) test=*# SELECT clock_timestamp(), pg_sleep(1), clock_timestamp(); clock_timestamp | pg_sleep | clock_timestamp -------------------------------+----------+------------------------------- 2023-01-18 13:48:55.309987+01 | | 2023-01-18 13:48:56.311001+01 (1 row) test=*# COMMIT; COMMIT |
As you can see the timestamp changes all the time.
When working with time it is important to understand which time of timestamp is needed. Do you need a constant return value or do you really need the current time? Depending on what is needed PostgreSQL provides the right function for you.
If you want to learn more about PostgreSQL check out Laurenz Albe's blog post about HOT Updates
+43 (0) 2622 93022-0
office@cybertec.at
You are currently viewing a placeholder content from Facebook. To access the actual content, click the button below. Please note that doing so will share data with third-party providers.
More InformationYou are currently viewing a placeholder content from X. To access the actual content, click the button below. Please note that doing so will share data with third-party providers.
More Information