Preamble
You will learn how to create, drop, disable, and enable a primary key in PostgreSQL with syntax and examples.
What is the primary key in PostgreSQL?
In PostgreSQL, a primary key is a single field or a combination of fields that uniquely define a record. None of the fields that are part of the primary key can contain the value NULL. A table can have only one primary key.
Note:
- In PostgreSQL, the primary key is created using the CREATE TABLE operator or ALTER TABLE operator.
You use ALTER TABLE in PostgreSQL to add or delete the primary key.
Create a primary key with the CREATE TABLE operator
You can create a primary key in PostgreSQL using the CREATE TABLE operator.
The syntax for creating a primary key with CREATE TABLE in PostgreSQL
CREATE TABLE table_name
(
column1 datatype [ NULL | NOT NULL ],
column2 datatype [ NULL | NOT NULL ],
…
CONSTRAINT constraint_name
PRIMARY KEY (index_col1, index_col2,... index_col_n)
);
OR
CREATE TABLE table_name
(
column1 datatype CONSTRAINT constraint_name PRIMARY KEY,
column2 datatype [ NULL | NOT NULL ],
…
);
- table_name – The name of the table you want to create.
- column1, column2 – The columns you want to create in the table.
- Table_name – Name of the primary key.
- index_col1, index_col2,… index_col_n – The columns that make up the primary key.
Consider an example of how to create a primary key using the CREATE TABLE operator in PostgreSQL.
CREATE TABLE order_details
( order_detail_id integer NOT NULL,
order_id integer NOT NULL,
order_date date,
size integer,
notes varchar(200),
CONSTRAINT order_details_pk PRIMARY KEY (order_detail_id)
);
Or you can also create a primary key in the order_details table using the following syntax:
CREATE TABLE order_details
( order_detail_id integer CONSTRAINT order_details_pk PRIMARY KEY,
order_id integer NOT NULL,
order_date date,
size integer,
notes varchar(200)
);
In these two examples, we created a primary key in the order_details table named order_details_pk. It consists of only one column, the order_detail_id column.
We can also create a primary key with more than one field, as in the example below:
CREATE TABLE order_details
( order_date date NOT NULL,
customer_id integer NOT NULL,
size integer,
notes varchar(200),
CONSTRAINT order_details_pk PRIMARY KEY (order_date, customer_id)
);
In this example, a primary key is created with the name order_details_pk, which consists of a combination of order_date and customer_id columns. Thus, each combination of order_date and customer_id must be unique in the order_details table.
Create a primary key using the ALTER TABLE operator
You can create a primary key in PostgreSQL using the ALTER TABLE operator.
The syntax for creating a primary key using the ALTER TABLE operator in PostgreSQL
ALTER TABLE table_name
ADD CONSTRAINT [ constraint_name ]
PRIMARY KEY (index_col1, index_col2,... index_col_n)
- table_name – The name of the table to change.
- constraint_name – The name of the primary key.
- index_col1, index_col2,… index_col_n – The columns that make up the primary key.
Consider an example of how to create a primary key using the ALTER TABLE operator in PostgreSQL.
ALTER TABLE order_details
ADD CONSTRAINT order_details_pk
PRIMARY KEY (order_detail_id);
In this example, we created a primary key for an existing order_details table named order_details_pk. It consists of an order_detail_id column.
We can also create a primary key with more than one field, as in the example below:
ALTER TABLE order_details
ADD CONSTRAINT order_details_pk
PRIMARY KEY (order_date, customer_id);
In this example, we have created a primary contact_pk key which consists of a combination of last_name and first_name columns.
Drop the primary key
You can delete a primary key in PostgreSQL using the ALTER TABLE operator.
The syntax for removing the primary key in PostgreSQL
ALTER TABLE table_name
DROP CONSTRAINT constraint_name;
- table_name – The name of the table to change.
- constraint_name – The name of the primary key that you want to delete.
Let’s consider an example of how to delete a primary key using the ALTER TABLE operator in PostgreSQL.
ALTER TABLE order_details
DROP CONSTRAINT order_details_pk;
In this example, we have removed the primary key from the contacts table. We do not need to give the name of the primary key, because there can only be one key in the table.
PostgreSQL Primary Key | Course
About Enteros
IT organizations routinely spend days and weeks troubleshooting production database performance issues across multitudes of critical business systems. Fast and reliable resolution of database performance problems by Enteros enables businesses to generate and save millions of direct revenue, minimize waste of employees’ productivity, reduce the number of licenses, servers, and cloud resources and maximize the productivity of the application, database, and IT operations teams.
The views expressed on this blog are those of the author and do not necessarily reflect the opinions of Enteros Inc. This blog may contain links to the content of third-party sites. By providing such links, Enteros Inc. does not adopt, guarantee, approve, or endorse the information, views, or products available on such sites.
Are you interested in writing for Enteros’ Blog? Please send us a pitch!
RELATED POSTS
How to Modernize Retail Cost Management with Enteros Database Performance Intelligence and Cost Estimation
- 8 June 2026
- Database Performance Management
Introduction The retail industry is undergoing a significant digital transformation as organizations invest heavily in ecommerce platforms, omnichannel experiences, customer engagement technologies, and cloud-native infrastructures. While these innovations help retailers improve customer experiences and accelerate growth, they also create new challenges related to operational costs, infrastructure efficiency, and technology performance. Modern retail ecosystems now support: … Continue reading “How to Modernize Retail Cost Management with Enteros Database Performance Intelligence and Cost Estimation”
Why Proactive Database Monitoring Is Essential for Enterprise Application Reliability
In today’s digital-first business environment, enterprise applications are the backbone of critical operations. From customer-facing platforms and financial systems to healthcare applications and SaaS products, organizations rely on applications to deliver seamless experiences, support business processes, and drive revenue growth. As customer expectations continue to rise, application reliability has become a key business differentiator. Users … Continue reading “Why Proactive Database Monitoring Is Essential for Enterprise Application Reliability”
How to Improve Fashion Ecommerce Performance with Enteros Database Analytics and AIOps Automation
Introduction The fashion industry has evolved into one of the most technology-driven sectors in the global economy. Modern fashion brands, retailers, and ecommerce platforms rely heavily on digital technologies to engage customers, manage inventory, personalize shopping experiences, and drive revenue growth. Today’s fashion ecommerce ecosystems support: Online storefronts Mobile shopping applications Inventory management systems Product … Continue reading “How to Improve Fashion Ecommerce Performance with Enteros Database Analytics and AIOps Automation”
How AI-Driven Database Observability Reduces Cloud Infrastructure Costs
Cloud computing has transformed the way organizations build, deploy, and scale applications. Modern enterprises increasingly rely on cloud-native architectures, distributed databases, microservices, and multi-cloud environments to support digital transformation initiatives and growing customer demands. While the cloud offers unprecedented scalability and flexibility, it also introduces a significant challenge: controlling infrastructure costs. According to industry reports, … Continue reading “How AI-Driven Database Observability Reduces Cloud Infrastructure Costs”