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
How Predictive Database Analytics Helps Optimize Cloud Resource Utilization
- 23 June 2026
- Database Performance Management
As enterprises continue migrating workloads to the cloud, optimizing resource utilization has become a critical business priority. Cloud infrastructure offers scalability, flexibility, and operational agility, but it also introduces new cost and performance challenges. Without proper visibility into workload behavior, organizations often struggle to balance application performance with infrastructure efficiency. At the center of this … Continue reading “How Predictive Database Analytics Helps Optimize Cloud Resource Utilization”
Why Proactive SQL Performance Monitoring Is Essential for Enterprise Growth
In today’s digital economy, enterprise growth depends heavily on application speed, scalability, and reliability. As businesses expand their digital services, customer interactions, transactions, analytics, and operational workloads grow exponentially. Behind nearly every business-critical application lies SQL-driven databases that process and manage massive amounts of structured data in real time. From financial transactions and e-commerce purchases … Continue reading “Why Proactive SQL Performance Monitoring Is Essential for Enterprise Growth”
How to Enable Data-Driven Media Growth with Enteros Cost Attribution and Software Management
- 22 June 2026
- Software Engineering
Introduction The media industry is experiencing one of the most significant transformations in its history. Streaming services, digital publishing platforms, online advertising ecosystems, video-on-demand applications, and content distribution networks have fundamentally changed how audiences consume content. Modern media organizations now operate highly complex digital ecosystems that support: Streaming platforms Digital publishing systems Video content delivery … Continue reading “How to Enable Data-Driven Media Growth with Enteros Cost Attribution and Software Management”
How to Enable Intelligent Wealth Management Operations with Enteros Database Software, AIOps Platform, and Gen AI
Introduction The wealth management industry is undergoing a major transformation. As investors demand personalized financial services, real-time portfolio visibility, and digital-first experiences, wealth management firms are increasingly relying on technology to drive operational efficiency, improve client engagement, and accelerate business growth. Modern wealth management organizations now support: Portfolio management platforms Wealth advisory applications Digital client … Continue reading “How to Enable Intelligent Wealth Management Operations with Enteros Database Software, AIOps Platform, and Gen AI”