Using PostgreSQL SERIAL to Create Auto-increment Column
Summary: in this tutorial, you will learn about the PostgreSQL SERIAL
pseudo-type and how to use the SERIAL
pseudo-type to define auto-increment columns in tables.
Introduction to the PostgreSQL SERIAL pseudo-type
In PostgreSQL, a sequence is a special kind of database object that generates a sequence of integers. A sequence is often used as the primary key column in a table.
When creating a new table, the sequence can be created through the SERIAL
pseudo-type as follows:
By assigning the SERIAL
pseudo-type to the id
column, PostgreSQL performs the following:
- First, create a sequence object and set the next value generated by the sequence as the default value for the column.
- Second, add a
NOT NULL
constraint to theid
column because a sequence always generates an integer, which is a non-null value. - Third, assign the owner of the sequence to the
id
column; as a result, the sequence object is deleted when theid
column or table is dropped
Behind the scenes, the following statement:
is equivalent to the following statements:
PostgreSQL provides three serial pseudo-types SMALLSERIAL
, SERIAL
, and BIGSERIAL
with the following characteristics:
Name | Storage Size | Range |
---|---|---|
SMALLSERIAL | 2 bytes | 1 to 32,767 |
SERIAL | 4 bytes | 1 to 2,147,483,647 |
BIGSERIAL | 8 bytes | 1 to 9,223,372,036,854,775,807 |
PostgreSQL SERIAL examples
Let’s take some examples of using the SERIAL columns.
1) Basic PostgreSQL SERIAL example
It is important to note that the SERIAL
does not implicitly create an index on the column or make the column the primary key column. However, this can be done easily by specifying the PRIMARY KEY
constraint for the SERIAL
column.
The following statement creates the fruits
table with the id
column as the SERIAL
column:
To assign a default value to a serial column when inserting a row into the table, you ignore the column name or use the DEFAULT
keyword in the INSERT
statement. For example:
Or
PostgreSQL inserted two rows into the fruits
table with the values for the id
column are 1 and 2.
2) Getting the sequence name
To get the sequence name of a SERIAL
column in a table, you use the pg_get_serial_sequence()
function as follows:
You can pass a sequence name to the currval()
function to get the recent value generated by the sequence. For example, the following statement returns the recent value generated by the fruits_id_seq
object:
3) Retrieving the generated value
If you want to get the value generated by the sequence when you insert a new row into the table, you use the RETURNING id
clause in the INSERT
statement.
The following statement inserts a new row into the fruits
table and returns the value generated for the id column.
The sequence generator operation is not transaction-safe. It means that if two concurrent database connections attempt to get the next value from a sequence, each client will get a different value.
If one client rolls back the transaction, the sequence number of that client will be unused, creating a gap in the sequence.
4) Adding a serial column to an existing table
First, create a new table called baskets
without a primary key column:
Second, add a SERIAL
column to the baskets
table:
Third, describe the table baskets
to verify the change:
Output:
Summary
- Use the PostgreSQL pseudo-type
SERIAL
to create an auto-increment column for a table.