So, I am working on a View that calls a function. Before I declare the function or View, I am defining a custom composite record. Then, I declare a vararray of type:my custom composite record. Within the function, I then define a new variable of type: vararray mentioned earlier. (I will show example below for clarification). However, when I try to call newCustomArray.extends(1), I get a syntax error. I did not get an error when I was just testing the function by itself (without a view). So I am a little confused, also a little new to plsql for edb postgres. Anyone have any ideas on what I am doing wrong? Here is the code below:
CREATE TYPE public.Question AS
(
"ID" integer,
"QID" integer,
"Order" integer,
"IsNeeded" boolean,
"FieldName" character varying(150),
"OtherField" boolean
);
CREATE TYPE public.infoarray IS VARYING ARRAY(40) OF public.Question;
......
(within function)
rec_anotherinfoarray public.infoarray := public.infoarray();
rec_anotherinfoarray.extend(1) --> causing all the syntax errors (SQL state 42601)