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 to Improve Retail Profitability with Enteros Cost Attribution, Database Analytics, and Software Management
- 21 June 2026
- Software Engineering
Introduction The retail industry is evolving at an unprecedented pace. Driven by ecommerce growth, omnichannel experiences, customer personalization, and digital transformation initiatives, retailers are investing heavily in technology to remain competitive. Modern retail organizations rely on: Ecommerce platforms Point-of-sale (POS) systems Inventory management applications Customer engagement platforms Supply chain systems Retail analytics environments AI-powered recommendation … Continue reading “How to Improve Retail Profitability with Enteros Cost Attribution, Database Analytics, and Software Management”
How to Drive Education Platform Growth with Enteros Database Performance Analytics and RevOps Efficiency
Introduction The education sector is experiencing a profound digital transformation. Universities, colleges, online learning providers, K-12 institutions, and corporate learning platforms are increasingly relying on technology to deliver engaging learning experiences, manage academic operations, and support student success. Modern education ecosystems now support: Learning Management Systems (LMS) Student Information Systems (SIS) Online learning platforms Virtual … Continue reading “How to Drive Education Platform Growth with Enteros Database Performance Analytics and RevOps Efficiency”
Why Intelligent Database Workload Management Is Essential for High-Growth SaaS Platforms
- 19 June 2026
- Database Performance Management
Introduction Telecommunications providers are operating in one of the most competitive and technology-intensive industries in the world. While demand for connectivity, mobile services, broadband access, and digital experiences continues to grow, profit margins are increasingly challenged by rising infrastructure costs, complex network operations, and expanding customer expectations. Modern telecom organizations must support: 5G networks Cloud-native … Continue reading “Why Intelligent Database Workload Management Is Essential for High-Growth SaaS Platforms”
Reducing Operational Complexity with AI-Driven Database Observability and AIOps
Modern enterprises operate in increasingly complex digital environments. Applications now span hybrid cloud infrastructures, multi-cloud deployments, containerized platforms, microservices architectures, and globally distributed data systems. While this transformation enables greater scalability, agility, and innovation, it also creates significant operational challenges for IT and engineering teams. At the heart of these complex environments lies the database … Continue reading “Reducing Operational Complexity with AI-Driven Database Observability and AIOps”