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
Enhancing Database Performance and Scalability in Digital Banking Platforms with Advanced Analytics
- 14 May 2026
- Database Performance Management
Introduction Digital banking has transformed the financial services landscape. Customers now expect seamless mobile banking experiences, instant payments, real-time transaction confirmations, and 24/7 service availability. These modern banking services rely heavily on high-performance database infrastructures that support massive transaction volumes and complex analytics workloads. At the core of every digital banking interaction—whether it is a … Continue reading “Enhancing Database Performance and Scalability in Digital Banking Platforms with Advanced Analytics”
How Intelligent Database Analytics Improves Performance and Reliability in Modern E-Learning Platforms
Introduction The global shift toward digital education has transformed how institutions deliver learning experiences. Universities, online learning platforms, corporate training systems, and educational technology companies now rely heavily on digital platforms to deliver courses, manage learning data, and support millions of simultaneous users. Behind every online lecture, virtual classroom, exam submission, and learning analytics dashboard … Continue reading “How Intelligent Database Analytics Improves Performance and Reliability in Modern E-Learning Platforms”
How Intelligent Database Analytics Improves Performance and Scalability in Modern Retail Platforms
- 13 May 2026
- Database Performance Management
Introduction Retail has undergone a dramatic transformation over the past decade. Today’s retailers operate in a digital-first economy where customers expect fast, personalized, and seamless shopping experiences across multiple channels. From e-commerce platforms and mobile apps to in-store point-of-sale systems and inventory management tools, every component of modern retail relies on efficient data infrastructure. At … Continue reading “How Intelligent Database Analytics Improves Performance and Scalability in Modern Retail Platforms”
How to Accelerate Insurance Sector Growth with Enteros Cost Attribution and RevOps Strategy
Introduction The insurance industry is rapidly evolving as organizations embrace digital transformation, data-driven decision-making, and customer-centric business models. Modern insurers must deliver seamless digital experiences, process claims efficiently, personalize policy offerings, and maintain operational agility in an increasingly competitive market. At the same time, insurance companies face rising operational costs, growing regulatory complexity, and increasing … Continue reading “How to Accelerate Insurance Sector Growth with Enteros Cost Attribution and RevOps Strategy”