Preamble
You can grant GRANT and REVOKE rights for different database objects in PostgreSQL. We will see how to grant and revoke table privileges in PostgreSQL.
Grant privileges for a table
You can give users different privileges for tables. These permissions can be any combination of SELECT, INSERT, UPDATE or DELETE, INDEX, CREATE, ALTER, DROP, GRANT OPTION, or ALL.
Syntax to provide table privileges in PostgreSQL
GRANT privileges ON object TO user;
privileges
Privileges to appoint. This can be any of the following values:
|
Privileges
|
Description
|
|---|---|
|
SELECT
|
Ability to execute SELECT operators for a table.
|
|
INSERT
|
Ability to execute INSERT operators for a table.
|
|
UPDATE
|
Ability to execute UPDATE operators for a table.
|
|
DELETE
|
Ability to execute DELETE operators for a table.
|
|
TRUNCATE
|
Ability to execute TRUNCATE operators on a table.
|
|
REFERENCES
|
Ability to create external keys (requires privileges for both parent and child tables).
|
|
TRIGGER
|
Ability to create triggers for a table.
|
|
CREATE
|
Ability to perform CREATE TABLE operators.
|
|
ALL
|
Provides all privileges.
|
- object – The name of the database object for which you grant privileges. In case you grant privileges for a table, this will be the name of the table.
- user – The name of the user to whom these privileges will be granted.
Some examples to understand how to grant table privileges in PostgreSQL
For example, if you want to grant SELECT, INSERT, UPDATE, and DELETE privileges to a table named products for a user named trizor, you must run the following GRANT statement:
GRANT SELECT, INSERT, UPDATE, DELETE ON products TO trizor;
You can also use the keyword ALL to specify that you want to grant all privileges to a user named trizor. For example:
GRANT ALL ON products TO trizor;
If you want to grant all users only SELECT access to the products table, you can grant PUBLIC privileges. For example:
GRANT SELECT ON products TO PUBLIC;
Recall the privileges for the table
Once you grant the privileges, you may need to cancel some or all of these privileges. To do this you can run the revoke command. You can revoke any combination of SELECT, INSERT, UPDATE, DELETE, TRUNCATE, REFERENCES, TRIGGER, CREATE, or ALL.
The syntax for revoking table privileges in PostgreSQL
REVOKE privileges ON object FROM user;
privileges
Privileges for review. This can be any of the following values:
|
Privileges
|
Description
|
|---|---|
|
SELECT
|
Ability to execute SELECT operators for a table.
|
|
INSERT
|
Ability to execute INSERT operators for a table.
|
|
UPDATE
|
Ability to execute UPDATE operators for a table.
|
|
DELETE
|
Ability to execute DELETE operators for a table.
|
|
TRUNCATE
|
Ability to execute TRUNCATE operators on a table.
|
|
REFERENCES
|
Ability to create external keys (requires privileges for both parent and child tables).
|
|
TRIGGER
|
Ability to create triggers for a table.
|
|
CREATE
|
Ability to perform CREATE TABLE operators.
|
|
ALL
|
Provides all privileges
|
- object – The name of the database object for which you are revoking the privileges. In the case of revocation of privileges for a table, this will be the name of the table.
- user – The name of the user for whom the privileges are to be revoked.
Examples of how to revoke privileges for a table in PostgreSQL
For example, if you want to revoke the DELETE and UPDATE privileges for a table named products for a user named trizor, you must run the following REVOKE statement:
REVOKE DELETE, UPDATE ON products FROM trizor;
If you want to revoke all table privileges for a user named trizor, you can use the ALL keyword as follows:
REVOKE ALL ON products FROM trizor;
If you granted SELECT * (i.e. all users) privileges in the products table and wanted to revoke those privileges, you can use the following REVOKE statement:
REVOKE SELECT ON products FROM PUBLIC;
PostgreSQL DBA: Grant and Revoke Privileges in PostgreSQL
About Enteros
Enteros offers a patented database performance management SaaS platform. It proactively identifies root causes of complex business-impacting database scalability and performance issues across a growing number of clouds, RDBMS, NoSQL, and machine learning database platforms.
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
Optimizing Digital Payment Platforms with Intelligent Database Performance Monitoring
- 2 May 2026
- Database Performance Management
Introduction Digital payment platforms have become the backbone of the global digital economy. From mobile wallets and online banking to peer-to-peer transfers and real-time payment gateways, billions of financial transactions are processed every day. Consumers and businesses expect instant, secure, and reliable payment experiences, making performance a critical factor for payment infrastructure. Behind every seamless … Continue reading “Optimizing Digital Payment Platforms with Intelligent Database Performance Monitoring”
How AI-Powered Database Analytics is Transforming Financial Services Infrastructure
Introduction The financial services industry is undergoing a massive digital transformation. Banks, insurance providers, fintech companies, and investment firms now rely heavily on advanced data platforms to deliver real-time services such as digital banking, payment processing, fraud detection, and risk analytics. Every transaction—from credit card approvals to stock trading—depends on reliable and high-performing databases. However, … Continue reading “How AI-Powered Database Analytics is Transforming Financial Services Infrastructure”
Improving Financial Services Platforms with AI-Driven Database Performance Monitoring
- 30 April 2026
- Database Performance Management
Introduction The financial services industry is undergoing a rapid digital transformation. From online banking and digital wallets to algorithmic trading, payment gateways, and mobile-first financial applications, modern financial platforms process massive volumes of transactions and data every second. Behind every payment authorization, fraud detection check, investment trade, or account update lies a complex network of … Continue reading “Improving Financial Services Platforms with AI-Driven Database Performance Monitoring”
How to Achieve Scalable AI Growth with Enteros, AI SQL, Cloud FinOps, and AI Database Management
Introduction Artificial Intelligence (AI) is no longer a futuristic concept—it is a core driver of modern business growth. Organizations across industries are leveraging AI to automate operations, enhance decision-making, personalize customer experiences, and unlock new revenue streams. However, scaling AI initiatives is far from simple. As AI workloads grow, they demand massive data processing capabilities, … Continue reading “How to Achieve Scalable AI Growth with Enteros, AI SQL, Cloud FinOps, and AI Database Management”