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
Scaling AI Without Overspend: How Enteros Brings Financial Clarity to AI Platforms
- 22 January 2026
- Database Performance Management
Introduction Artificial intelligence is no longer experimental. Across industries, AI platforms now power core business functions—recommendation engines, fraud detection, predictive analytics, conversational interfaces, autonomous decision systems, and generative AI applications. But as AI adoption accelerates, a critical problem is emerging just as fast: AI is expensive—and most organizations don’t fully understand why. Read more”Indian Country” … Continue reading “Scaling AI Without Overspend: How Enteros Brings Financial Clarity to AI Platforms”
AI-Native Database Performance Management for Real Estate Technology Enterprises with Enteros
Introduction Real estate has rapidly evolved into a technology-driven industry. From digital property marketplaces and listing platforms to smart building systems, valuation engines, CRM platforms, and AI-powered analytics, modern real estate enterprises run on data-intensive technology stacks. At the center of this transformation lies a critical foundation: databases. Every property search, pricing update, lease transaction, … Continue reading “AI-Native Database Performance Management for Real Estate Technology Enterprises with Enteros”
Driving RevOps Efficiency Through AI-Driven Database Optimization with Enteros
- 21 January 2026
- Database Performance Management
Introduction Revenue Operations (RevOps) has become the backbone of modern digital enterprises. By aligning sales, marketing, finance, and customer success, RevOps promises predictable growth, faster decision-making, and improved customer lifetime value. Yet, for many organizations, RevOps efficiency remains elusive. The missing link is often hidden deep within the technology stack: the database layer. Every revenue … Continue reading “Driving RevOps Efficiency Through AI-Driven Database Optimization with Enteros”
How Retail Companies Can Reduce Cloud Costs Through Database Optimization with Enteros
Introduction Retail has become one of the most data-intensive industries in the digital economy. Modern retailers rely on cloud-powered platforms to support omnichannel commerce, real-time inventory visibility, personalized recommendations, dynamic pricing, loyalty programs, supply chain optimization, and customer analytics. At the center of all these capabilities sits a critical layer: databases. Retail databases process millions … Continue reading “How Retail Companies Can Reduce Cloud Costs Through Database Optimization with Enteros”