Я пытаюсь вставить данные в составный массив в моей функции. Он должен принимать данные из типа составного массива параметра INPUT и хранить данные в параметре OUPUT того же типа.Composite Array Тип как параметр OUTPUT в PostgreSQL
CREATE TYPE public.type_x_type AS (x integer);
CREATE TYPE public.type_y_type AS(x integer,y integer);
Моя функция
CREATE OR REPLACE FUNCTION GET_PRICE_PC_X
(
IP_PRICE_INFO IN TYPE_X_TYPE[],
PC_COST OUT TYPE_Y_TYPE[],
OP_RESP_CODE OUT VARCHAR,
OP_RESP_MSG OUT VARCHAR
)
RETURNS RECORD AS $$
DECLARE
SELECTED_PRICE CURSOR(IP_PFCNTR INT)
FOR
SELECT ID, PHONE FROM CUSTOMER WHERE ID=IP_PFCNTR;
J NUMERIC(10);
BEGIN
J := 0;
FOR I IN ARRAY_LOWER(IP_PRICE_INFO,1) .. ARRAY_UPPER(IP_PRICE_INFO,1)
LOOP
FOR K IN SELECTED_PRICE(IP_PRICE_INFO[I].X)
LOOP
PC_COST := ROW(K.ID,K.PHONE);
END LOOP;
END LOOP;
OP_RESP_CODE :='000';
OP_RESP_MSG :='Success';
EXCEPTION
WHEN OTHERS THEN
OP_RESP_CODE :='200';
OP_RESP_MSG :=SQLERRM;
END;
$$ language 'plpgsql';
select * from GET_PRICE_PC_X(ARRAY[ROW(1)] :: TYPE_X_TYPE[]);
И я получаю ошибку ниже.
PC_COST | OP_RESPONSE_CODE | OP_RESP_MSG
---------------------------------------------------------
| 200 | malformed array literal: "(1,30003)"
Я буду называть этот тип OUT где-то, поэтому мне нужны данные, которые нужно вставить в массив.
Здравствуйте Павел, вы действительно, мой код выглядел дешево с неприятностью. :) Спасибо за помощь в любом случае. У меня есть один вопрос. Как получить доступ к одному столбцу из вывода. Мой вывод выглядит так: {{(31,23423423) "," (1,300074321) "}". И почему PC_COST: = '{}'; Это похоже на то, чтобы что-то сделать. – user1720827
(небытие (результат)) поле; '{}' является специальным литералом для пустого массива. Значение по умолчанию для PC_COST равно NULL, а NULL + any - NULL снова - поэтому PC_COST должен быть инициализирован для пустого массива - '{}' –