Preamble
You will learn how to create, update, and drop VIEWS in PostgreSQL with syntax and examples.
What is PostgreSQL VIEW?
In PostgreSQL, VIEW is not a physical table, but rather a virtual table created by a joins query that connects one or more tables.
Create VIEW
Syntax of CREATE VIEW operator in PostgreSQL
CREATE [OR REPLACE] VIEW view_name AS
SELECT columns
FROM tables
[WHERE conditions];
- OR REPLACE – Optional. If you do not specify this operator and VIEW already exists, the CREATE VIEW operator will return the error.
- view_name – The VIEW name you want to create in PostgreSQL.
- WHERE conditions – Optional. The conditions that must be met to enable entries in VIEW.
An example of how to use the CREATE VIEW statement to create a view in PostgreSQL
CREATE VIEW current_inventory AS
SELECT product_name, quantity
FROM products
WHERE quantity > 0;
This example CREATE VIEW will create a virtual table based on the resulting SELECT operator set. You can now query the PostgreSQL VIEW as follows:
SELECT *
FROM current_inventory;
Update VIEW
You can change the VIEW definition in PostgreSQL without removing it using the CREATE OR REPLACE VIEW statement.
The syntax for CREATE OR REPLACE VIEW in PostgreSQL
CREATE OR REPLACE VIEW view_name AS
SELECT columns
FROM table
WHERE conditions;
- view_name – The name of the view you want to update.
An example of how the CREATE OR REPLACE VIEW operator can be used in PostgreSQL
CREATE or REPLACE VIEW current_inventory AS
SELECT product_name, quantity, category_name
FROM products
INNER JOIN categories
ON products.category_id = categories.category_id
WHERE quantity > 0;
This CREATE OR REPLACE VIEW example would update the VIEW definition with the name current_inventory without removing it.
WARNING: THIS EXAMPLE WOULD UPDATE THE DEFINITION OF VIEW WITH THE NAME CURRENT_INVENTORY WITHOUT REMOVING IT
The CREATE OR REPLACE VIEW statement will work if you add columns to the view at the end of the list. However, it will be an error if you add new columns to the existing columns (i.e.: start or middle of an existing list).
In this case, do not use the CREATE OR REPLACE VIEW statement. It is better to delete VIEW and use the CREATE VIEW operator!
Drop VIEW
After creating VIEW in PostgreSQL, you can delete it using the Drop VIEW operator.
The syntax for Drop VIEW in PostgreSQL
Drop VIEW [IF EXISTS] view_name;
- view_name – The name of the view you want to delete.
- IF EXISTS – Optional. If you do not specify this option and VIEW does not exist, Drop VIEW will return the error.
An example of how to use the Drop VIEW operator in PostgreSQL
Drop VIEW current_inventory;
This example will delete a VIEW named current_inventory.
Postgres database views
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
From Data to Delivery: How Enteros Transforms D2C Brands Through Database Performance and Cloud FinOps
- 6 October 2025
- Database Performance Management
Introduction In the fast-evolving world of Direct-to-Consumer (D2C) brands, agility and performance are everything. D2C businesses thrive on personalization, speed, and customer trust — all of which depend on how efficiently data flows through their systems. Behind every product recommendation, every smooth checkout, and every on-time delivery is a complex network of databases, cloud infrastructure, … Continue reading “From Data to Delivery: How Enteros Transforms D2C Brands Through Database Performance and Cloud FinOps”
How Enteros AI Performance and Data Lake Optimization Are Powering Innovation in the Fashion Industry
Introduction The fashion industry, once ruled by instinct and creativity alone, is now undergoing a seismic transformation driven by data and artificial intelligence (AI). From forecasting trends to managing supply chains and customer experiences, data-driven insights are redefining how fashion brands operate. Central to this digital shift is the use of AI-driven performance management and … Continue reading “How Enteros AI Performance and Data Lake Optimization Are Powering Innovation in the Fashion Industry”
When Booking Systems Freeze: The Hidden IT Challenge Behind Aviation Disruptions
Behind every on-time departure, there’s an invisible network of data systems working in sync.But when that synchronization breaks — even for a few seconds — the result can ground entire fleets. The Hidden Digital Backbone of Aviation Today’s airlines and airport operators depend on complex ecosystems that process millions of real-time transactions per minute: Flight … Continue reading “When Booking Systems Freeze: The Hidden IT Challenge Behind Aviation Disruptions”
How Enteros AIOps and Generative AI Are Powering the Cloud Center of Excellence for Modern Banking
- 5 October 2025
- Database Performance Management
Introduction The modern banking industry is being reshaped by digital innovation. Artificial Intelligence (AI), automation, and cloud computing are no longer optional — they are the driving forces behind operational efficiency, customer personalization, and financial growth. Amid this technological transformation, banks are building Cloud Centers of Excellence (CCoE) to unify their cloud strategies, improve governance, … Continue reading “How Enteros AIOps and Generative AI Are Powering the Cloud Center of Excellence for Modern Banking”