Preamble
In this tutorial, you will learn how to declare variables in PostgreSQL using syntax and examples.
What is a variable in PostgreSQL?
In PostgreSQL, a variable allows a programmer to temporarily store data at runtime.
The syntax for declaring a variable in PostgreSQL
DECLARE variable_name [ CONSTANT ] datatype [ NOT NULL ] [ { DEFAULT |:= } initial_value ]
Parameters and arguments of variables
- variable_name – The name to be assigned to the variable.
- CONSTANT – Optional. If specified, the variable value cannot be changed after the initialization of the variable.
- datatype – The data type to be assigned to a variable.
- NOT NULL – Optional. If specified, the variable cannot contain the value of NULL.
- initial_value – Optional. This is the value originally assigned to a variable when it is declared. If no
- initial_value is specified, the variable is assigned a value of NULL.
Declaring a variable
Below is an example of a PostgreSQL declaration of a variable with vSite name.
DECLARE vSite varchar;
In this example, the variable vSite is declared as the varchar data type.
Then you can later set or change the value of the vSite variable as follows:
vSite:= 'Google.com';
This operator will set the vSite variable to ‘Google.com’.
Declaring a variable with an initial value (not a constant)
Below is an example of how to declare a variable in PostgreSQL and give it an initial value. This differs from the constant in that the variable value can be changed later.
DECLARE vSite varchar DEFAULT 'Google.com';
OR:
DECLARE vSite varchar:= 'Google.com';
This will declare the variable named vSite as varchar data type and assign the initial value to ‘Google.com’.
Later you can change the value of the vSite variable as follows:
vSite:= 'Bing.com';
This SET operator will change the value of the vSite variable from ‘Google.com’ to ‘Bing.com’.
Declaring a constant
Here is an example of how to declare a constant in PostgreSQL with the name vSiteID.
DECLARE vSiteID CONSTANT integer DEFAULT 50;
OR:
DECLARE vSiteID CONSTANT integer:= 50;
This will declare a constant named vSiteID as integer data type and assign an initial value of 50. Since this variable is declared using the CONSTANT keyword, you cannot change its value after initializing the variable.
Learn PostgreSQL Tutorial; Full Course for Beginners
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 Drive Intelligent Cloud Governance with Enteros Database Management Platform and AIOps
- 22 May 2026
- Database Performance Management
Introduction Cloud computing has become the foundation of modern digital transformation. Organizations across industries increasingly rely on cloud-native infrastructures, distributed applications, AI-driven services, and real-time analytics platforms to support innovation, scalability, and operational agility. Today’s enterprises operate highly complex cloud ecosystems that support: Business-critical applications Database environments Customer engagement platforms AI and machine learning workloads … Continue reading “How to Drive Intelligent Cloud Governance with Enteros Database Management Platform and AIOps”
How to Enhance Media Growth Strategies with Enteros Generative AI and Cost Management Analytics
Introduction The media industry is undergoing rapid transformation as organizations embrace digital platforms, cloud-native infrastructures, streaming technologies, AI-driven content strategies, and real-time audience analytics. Modern media companies must manage increasingly complex operational ecosystems while delivering personalized, high-quality experiences across multiple digital channels. Today’s media organizations rely heavily on digital technologies to support: Streaming platforms Content … Continue reading “How to Enhance Media Growth Strategies with Enteros Generative AI and Cost Management Analytics”
Enhancing Digital Banking Performance and Scalability with AI-Driven Database Analytics
- 21 May 2026
- Database Performance Management
Introduction Digital banking has transformed the global financial landscape. Customers now expect instant account access, real-time transactions, personalized financial services, and seamless digital experiences across mobile and web platforms. To meet these expectations, banks and financial institutions rely heavily on high-performance data infrastructure powered by complex database environments. Every digital banking operation—whether it involves payments, … Continue reading “Enhancing Digital Banking Performance and Scalability with AI-Driven Database Analytics”
How Intelligent Database Analytics Improves Performance and Reliability in Modern Healthcare Platforms
Introduction Healthcare organizations today operate in an increasingly data-driven environment. Hospitals, clinics, diagnostic centers, telemedicine platforms, and healthcare networks rely heavily on digital systems to manage patient records, medical imaging, billing systems, analytics platforms, and clinical workflows. At the center of these operations lies a complex healthcare data infrastructure powered by databases. These databases process … Continue reading “How Intelligent Database Analytics Improves Performance and Reliability in Modern Healthcare Platforms”