Fraud Blocker
  • Solution
    • Solution
      • Enteros – SaaS Database Solution
      • Enteros – Expert Services
    • Use Cases
      • DevOps
      • Monitoring Business Performance
      • IT Production Operations
      • Cloud Migration and Scaling
      • Continuous Delivery
      • NoSQL / MongoDB / Cassandra
    • Industries
      • Insurance
      • Social Media & Entertainment
      • Government
      • Financial Services
      • Healthcare
      • Retail
      • Telecom
    • Roles
      • IT Production Operations
      • CIO
      • Engineering Manager
      • CFO
  • Product
    • UpBeat
      • Database Performance Management SaaS
    • UpBeat Platform
      • Cloud Cost Waste Analyzer (vCore & Credit Optimization)
      • AiOps DB Analytical Engine for Anomaly and Root Causes Detection
      • Deep Workload Diagnostics for Oracle Systems
      • Remediation Engine for Oracle Infrastractures
      • UpBeat Labs
    • DPMDPM is an innovative platform for IT production database performance management. The first of its kind, DPM provides decision support for each stage of the performance problem lifecycle
      • Learn more
  • Company
    •  About
      • Overview
      • Contact Us
      • Support
      • Partners
      • Careers
      • News
      • Blog
      • Management
    • Feature articleNPMD solutions play a key role in helping IT ops support increasingly complex technologies and services with network visibility, detection of performance issues and root cause analysis
      • Read more
    •  
  • Search
  • See Demo
  • Contact
(408) 824-1292

Oracle Varrays.

See Live Demo Start Free Trial

Preamble

In Oracle PL/SQL Varray (an array with variable size) is an array whose number of elements can vary from zero (empty) to the declared maximum size.

To access a Varray element, use the variable_name(index) syntax:

  • The lower boundary of the index is 1; the upper boundary is the current number of elements.
  • The upper limit changes when the elements are added or removed, but it cannot exceed the maximum size.

When you store and extract a varray from the database, its indexes and the order of the elements remain stable.

Syntax to define and then declare a Varrays type variable in Oracle PL/SQL

Read morePostgreSQL CREATE USER statement

TYPE type_varray IS {VARRAY | VARYING ARRAY} (size_limit) OF element_type [NOT NULL];
v_arr type_varray;

Parameters and arguments of the array

  • type_varray – name of type Varray
  • element_type – any PL/SQL data type, except for REF CURSOR
  • size_limit is a positive integer literal representing the maximum number of elements in the array.
  • v_arr – the name of a variable of the Varray type

Note:

  • When defining a Varray type, you must specify its maximum size.

An example of how to use Varray in Oracle PL/SQL

DECLARE
TYPE Foursome IS VARRAY(4) OF VARCHAR2(15); -- Varray type

Read morePostgreSQL DROP TABLE statement

-- is a varray variable initialized by the constructor:

team Foursome := Foursome('John', 'Mary', 'Alberto', 'Juanita');

PROCEDURE print_team (heading VARCHAR2) IS
BEGIN
DBMS_OUTPUT.PUT_LINE(heading);

Read morePostgreSQL primary key

FOR i IN 1..4 LOOP
DBMS_OUTPUT.PUT_LINE(i) || '.' || team(i));
END LOOP;

DBMS_OUTPUT.PUT_LINE('---');
END;

BEGIN
print_team('2001 Team:');

team(3) := 'Pierre'; -- Change the values of the two elements
team(4) := 'Yvonne';
print_team('2005 Team:');

-- Call the constructor to assign new values to the Varray variable:

team := Foursome('Arun', 'Amitha', 'Allan', 'Mae');
print_team('2009 Team:');
END;

As a result, we get:
2001 Team:
1.John
2.Mary
3.Alberto
4.Juanita
---
2005 Team:
1.John
2.Mary
3.Pierre
4.Yvonne
---
2009 Team:
1.Arun
2.Amitha
3.Allan
4.Mae
---

In this example we defined Foursome as a local Varray type, declared a team variable of this type (initialized by the constructor) and defined the print_team procedure which printed Varray. The example calls the procedure three times:

  • after initializing the variable,
  • after changing values of two elements separately,
  • and after using the constructor to change the value of all elements.

Using Varray

Varray should be used when:

  • You know the maximum number of elements.
  • You access the elements in sequence.
  • Since you must store or retrieve all elements simultaneously, Varray may not be practical for a large number of elements.

PL/SQL tutorial: VARRAYs in Oracle Database

 

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

Modern Insurance IT Cost Management: Enteros’ AI SQL and AI/ML Intelligence Platform

  • 12 January 2026
  • Database Performance Management

    Introduction The insurance industry is in the middle of a profound digital transformation. From online policy issuance and real-time underwriting to automated claims processing, fraud detection, customer self-service portals, and AI-driven risk models, modern insurers operate as complex, data-intensive technology platforms. Behind every policy quote, claim decision, and customer interaction lies a sophisticated IT stack … Continue reading “Modern Insurance IT Cost Management: Enteros’ AI SQL and AI/ML Intelligence Platform”

    Continue Reading

    Modern Retail IT Cost Intelligence: Enteros’ Database Optimization and FinOps Platform

    • Database Performance Management

      Introduction Retail is no longer just about stores, products, and supply chains—it is a technology-driven, data-intensive business. Modern retailers operate complex digital ecosystems that include eCommerce platforms, mobile apps, omnichannel order management systems, pricing and promotion engines, loyalty programs, inventory optimization platforms, analytics pipelines, and AI-driven personalization services. At the heart of this ecosystem lies … Continue reading “Modern Retail IT Cost Intelligence: Enteros’ Database Optimization and FinOps Platform”

      Continue Reading

      Reducing Cloud Spend Through Intelligent Database Optimization in Retail SaaS with Enteros

      • Database Performance Management

        Introduction Retail SaaS platforms sit at the center of today’s digital commerce economy. From eCommerce storefronts and omnichannel order management systems to pricing engines, loyalty platforms, inventory optimization tools, and real-time analytics, modern retail software must operate at massive scale—24/7, across regions, channels, and customer touchpoints. Behind every seamless customer experience is a complex database … Continue reading “Reducing Cloud Spend Through Intelligent Database Optimization in Retail SaaS with Enteros”

        Continue Reading

        BFSI RevOps at Scale: How Enteros Uses Performance AI and FinOps Intelligence

        • Database Performance Management

          Introduction Banks, financial institutions, insurers, and fintech platforms (BFSI) are no longer defined solely by products like loans, policies, or payment instruments. Today, BFSI organizations operate as high-scale digital platforms, delivering real-time transactions, personalized financial products, instant risk decisions, and always-on customer experiences across mobile apps, APIs, branches, and partner ecosystems. Behind this digital transformation … Continue reading “BFSI RevOps at Scale: How Enteros Uses Performance AI and FinOps Intelligence”

          Continue Reading

          Company

          • Production Database Performance Management
          • Enteros Professional Expert Services
          • NoSQL
          • Contact Us

          Solutions

          • DevOps
          • IT Production Operations
          • CFO: Maximize Financial Efficiency with Augmented FinOps
          • Engineering Manager
          • Retail

          UpBeat SaaS

          • Performance Explorer-i – Oracle Database Performance Management
          • High Load Capture – High Precision Database Performance Management
          • DBAct
          • Grid2Go – Advanced Database Analysis
          • Load2Test for Databases

          Resources

          • Verticals
          • Case Studies
          • UpBeat Access
          • UpBeat Documentation
          • Privacy Policy
          • Terms of Service

          Connect with Us

          Copyright © 2026 | Enteros, Inc. All Rights Reserved

          🎉 Thank you for subscribing!

          You're now on the list for database FinOps strategies and performance insights.