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
Eliminating Growth Friction: How Enteros Aligns Database Performance, Cloud FinOps, and RevOps
- 28 January 2026
- Database Performance Management
Introduction For modern enterprises, growth is no longer limited by market demand alone—it is increasingly constrained by technology efficiency. As organizations scale digital platforms, launch new products, expand globally, and adopt AI-driven services, hidden friction inside their technology stack quietly erodes margins, slows execution, and undermines revenue outcomes. At the center of this friction sits … Continue reading “Eliminating Growth Friction: How Enteros Aligns Database Performance, Cloud FinOps, and RevOps”
AI SQL-Powered Database Management: Enteros’ Performance Intelligence Platform for Tech Enterprises
Introduction Technology enterprises today operate at unprecedented scale and speed. SaaS platforms, cloud-native applications, AI services, data marketplaces, and digital ecosystems now serve millions of users globally—often in real time. At the heart of this digital machinery lie databases. Databases power application responsiveness, AI pipelines, analytics engines, customer experiences, and revenue-generating workflows. Yet as technology … Continue reading “AI SQL-Powered Database Management: Enteros’ Performance Intelligence Platform for Tech Enterprises”
Keeping Operations Running at Scale: Enteros’ AIOps-Driven Database Performance Platform
- 27 January 2026
- Database Performance Management
Introduction In manufacturing plants and insurance enterprises alike, operational continuity is non-negotiable. A delayed production schedule, a failed claims transaction, or a slow underwriting system can ripple into lost revenue, regulatory exposure, and eroded customer trust. At the heart of these operations sit databases—quietly powering everything from shop-floor automation and supply chain planning to policy … Continue reading “Keeping Operations Running at Scale: Enteros’ AIOps-Driven Database Performance Platform”
Managing Real Estate Data at Scale: Enteros AI Platform for Database Performance and Cost Estimation
Introduction The real estate sector has undergone a dramatic digital transformation over the past decade. From commercial real estate (CRE) platforms and property management systems to residential marketplaces, smart buildings, and PropTech startups, modern real estate enterprises are now fundamentally data-driven organizations. Behind digital leasing platforms, pricing engines, tenant experience apps, IoT-enabled buildings, analytics dashboards, … Continue reading “Managing Real Estate Data at Scale: Enteros AI Platform for Database Performance and Cost Estimation”