rules repository

G-9105

🆓
Warning

Always follow naming conventions for collection variables (arrays/tables).

Reason

PL/SQL identifiers share the same namespace as SQL identifiers. Follow naming conventions to prevent naming conflicts, improve readability, and clearly indicate the scope without forcing the use of qualified names. A common practice is to use a prefix and/or suffix to distinguish the identifier types.

Local variables for a collection type (array/table). Can only be distinguished from general local variables if the collection type is declared in the same file.

Example

Non-Compliant Example

declare
   type t_varray_type is varray(10) of string;
   array1 t_varray_type;
   type t_nested_table_type is table of string;
   array2 t_nested_table_type;
   type t_assoc_array_type is table of string index by pls_integer;
   array3 t_assoc_array_type;
begin
   null;
end;
/
Issues
LineColumnMessage
34Collection variable array1 does not match '^t_[a-z0-9$#_]+$'.
54Collection variable array2 does not match '^t_[a-z0-9$#_]+$'.
74Collection variable array3 does not match '^t_[a-z0-9$#_]+$'.

Compliant Solution - ★★★★★

declare
   type t_varray_type is varray(10) of string;
   t_array1 t_varray_type;
   type t_nested_table_type is table of string;
   t_array2 t_nested_table_type;
   type t_assoc_array_type is table of string index by pls_integer;
   t_array3 t_assoc_array_type;
begin
   null;
end;
/

Parameters

Use parameters to customize the rule to your needs.

ParameterDescriptionDefault Value
CollectionPatternCase-insensitive regular expression pattern for PL/SQL local variables of type array/table.^t_[a-z0-9$#_]+$

References