Create Table with Auto-increment ID in PostgreSQL Database
In PostgreSQL, creating a table with an auto-incrementing ID column is straightforward using the SERIAL
or GENERATED AS IDENTITY
data types. These data types automatically generate a unique value for the ID column whenever a new row is inserted.
In this tutorial, we will cover how to create tables with auto-increment IDs, including examples for starting at a specific value and incrementing by a custom amount.
Examples for Creating Table with Auto-increment ID
The following are examples where we create a table with Auto-increment ID using SERIAL, create a table with Auto-increment ID starting from a specific value, create a table with Auto-increment ID with custom increment.
Example 1: Basic Auto-increment ID Using SERIAL
To create a table with an auto-incrementing ID column using SERIAL
, use the following syntax:
CREATE TABLE employees (
employee_id SERIAL PRIMARY KEY,
employee_name VARCHAR(100) NOT NULL,
department VARCHAR(50)
);
data:image/s3,"s3://crabby-images/39d60/39d607f4dd5a93f3239cbf2f9279dc39d03ddbc3" alt="PostgreSQL - Basic Auto-increment ID Using SERIAL"
Explanation:
- The
SERIAL
data type automatically creates a sequence to generate unique values for theemployee_id
column. - Each new row inserted into the
employees
table will have an incrementing value in theemployee_id
column.
Insert sample data into the table:
INSERT INTO employees (employee_name, department)
VALUES
('Alice', 'HR'),
('Bob', 'IT'),
('Charlie', 'Finance');
data:image/s3,"s3://crabby-images/65627/65627a8839fdc16175b94d47757eae7b607133ef" alt="PostgreSQL - inserting rows to table"
View the table data:
SELECT * FROM employees;
data:image/s3,"s3://crabby-images/bf4e7/bf4e7787e265a32cb33ce60b9cfc949c037124f1" alt="PostgreSQL - select table"
Each new row inserted into the employees
table has an incrementing value in the employee_id
column, starting from 1, and incrementing in steps of one.
Example 2: Auto-increment ID Starting from a Specific Value
You can customize the starting value of the auto-increment column by manipulating the underlying sequence:
CREATE TABLE departments (
department_id SERIAL PRIMARY KEY,
department_name VARCHAR(100) NOT NULL
);
-- Set the starting value of the sequence
ALTER SEQUENCE departments_department_id_seq RESTART WITH 100;
data:image/s3,"s3://crabby-images/d3275/d32757714e3cb48b8910ff2d34ebb4bd57adae8c" alt="PostgreSQL - Auto-increment ID Starting from a Specific Value"
Explanation:
- The
SERIAL
data type automatically creates a sequence nameddepartments_department_id_seq
. - The
ALTER SEQUENCE
command sets the starting value of the sequence to 100.
Insert sample data:
INSERT INTO departments (department_name)
VALUES
('HR'),
('IT'),
('Finance');
data:image/s3,"s3://crabby-images/adf6f/adf6fc2467905041a9b964a5c118a76dbc59b05d" alt="PostgreSQL - insert into table"
View the table data to confirm the custom starting value:
SELECT * FROM departments;
data:image/s3,"s3://crabby-images/e7909/e7909832f945d95a3d1f07ab4fdae8c82c387c09" alt="PostgreSQL - select table"
The starting value of department_id
is set to 100, and increments by one for every subsequent entry.
Example 3: Auto-increment ID with Custom Increment
You can customize the increment value of the auto-increment column by modifying the sequence:
CREATE TABLE projects (
project_id SERIAL PRIMARY KEY,
project_name VARCHAR(100) NOT NULL
);
-- Set the sequence to increment by 5
ALTER SEQUENCE projects_project_id_seq INCREMENT BY 5;
data:image/s3,"s3://crabby-images/d1eb6/d1eb6dc991d09704cfb2d0cf016e10569bacf9b9" alt="PostgreSQL - Auto-increment ID with Custom Increment"
Explanation:
- The
SERIAL
data type creates a sequence namedprojects_project_id_seq
. - The
ALTER SEQUENCE
command sets the increment value of the sequence to 5, so the IDs will be 1, 6, 11, and so on.
Insert sample data:
INSERT INTO projects (project_name)
VALUES
('Project A'),
('Project B'),
('Project C');
data:image/s3,"s3://crabby-images/5838c/5838cf6c5cf8d4251448892f223b8080ce120a02" alt="PostgreSQL - insert into table"
View the table data:
SELECT * FROM projects;
data:image/s3,"s3://crabby-images/d0dde/d0dde7c78dfb6878b88853cc9ed5b4920145a07f" alt="PostgreSQL - select from table"
The ALTER SEQUENCE
command has set the increment value of the sequence to 5, so the IDs are 1, 6, 11.
Example 4: Using GENERATED AS IDENTITY
PostgreSQL 10 introduced the GENERATED AS IDENTITY
data type as a more standardized way to define auto-incrementing columns. Here’s an example:
CREATE TABLE tasks (
task_id INT GENERATED ALWAYS AS IDENTITY PRIMARY KEY,
task_name VARCHAR(100) NOT NULL
);
data:image/s3,"s3://crabby-images/4cd4c/4cd4ca573f16ccdd8a11d47318c685dc0a776e1c" alt="PostgreSQL - Using GENERATED AS IDENTITY"
Explanation:
- The
GENERATED ALWAYS AS IDENTITY
clause generates unique values for thetask_id
column. - This method is more ANSI SQL compliant than using
SERIAL
.
Insert sample data:
INSERT INTO tasks (task_name)
VALUES
('Task 1'),
('Task 2');
data:image/s3,"s3://crabby-images/f028a/f028a59e4215652ec783f83f1ce411f396568338" alt="PostgreSQL - insert into table"
View the table data:
SELECT * FROM tasks;
data:image/s3,"s3://crabby-images/84e88/84e889b35bae879a353f05a7a79e8d40591b970e" alt="PostgreSQL - select from table"
Conclusion
PostgreSQL provides multiple ways to define an auto-incrementing ID column, including SERIAL
and GENERATED AS IDENTITY
. You can further customize the behavior of the ID column by modifying the sequence for starting values, increments, and more.