PostgreSQL CURRENT_TIMESTAMP Function
Summary: in this tutorial, you will learn how to use the PostgreSQL CURRENT_TIMESTAMP()
function to get the current date and time with the timezone.
Introduction to PostgreSQL CURRENT_TIMESTAMP() function
The CURRENT_TIMESTAMP
function returns the current date and time with the timezone.
Here’s the basic syntax of the PostgreSQL CURRENT_TIMESTAMP()
function:
The PostgreSQL CURRENT_TIMESTAMP()
function accepts one optional argument:
precision
: specifies the number of digits in the fractional seconds precision in the second field of the result.
If you omit the precision
argument, the CURRENT_TIMESTAMP()
function will return a TIMESTAMP
with a timezone that includes the full fractional seconds precision available.
The CURRENT_TIMESTAMP()
function returns a TIMESTAMP WITH TIME ZONE
representing the date and time at which the transaction started.
PostgreSQL CURRENT_TIMESTAMP function examples
Let’s explore some examples of using the CURRENT_TIMESTAMP
function.
1) Basic CURRENT_TIMESTAMP function example
The following example shows how to use the CURRENT_TIMESTAMP()
function to get the current date and time:
The result is:
Internally, the CURRENT_TIMESTAMP()
is implemented with the NOW()
function, therefore, the column alias is NOW
.
Like the NOW()
function, the CURRENT_TIMESTAMP()
function can be used as the default value of a timestamp column.
2) Using the PostgreSQL CURRENT_TIMESTAMP function as the default value of a column
First, create a table called note
:
The default value of the created_at
column is provided by the result of the CURRENT_TIMESTAMP()
function.
Second, insert a new row into the note
table:
In this statement, we don’t specify the value of the created_at
column. Therefore, it takes the result of the CURRENT_TIMESTAMP
at which the transaction started.
Third, verify the insert:
The following picture illustrates the result:
The output indicates that the created_at
column is populated by the date and time at which the statement was executed.
In PostgreSQL, the TRANSACTION_TIMESTAMP()
function is synonymous with the CURRENT_TIMESTAMP
function. However, the name of the function TRANSACTION_TIMESTAMP
more explicitly conveys the meaning of the return value.
Summary
- Use the PostgreSQL
CURRENT_TIMESTAMP()
to get the date and time at which the transaction starts.