Postgresql存储过程多维数组参数中的输入意外结束
我已经在PostgreSql中构建了存储过程,它接受多维数组参数,如下所示Postgresql存储过程多维数组参数中的输入意外结束,postgresql,stored-procedures,postgresql-9.4,Postgresql,Stored Procedures,Postgresql 9.4,我已经在PostgreSql中构建了存储过程,它接受多维数组参数,如下所示 SELECT horecami.insert_obj_common( '{"(5, 2, LLLLL rest, 46181, a@a.com, ooo, kkk, 12:09, 20:40, 23, true, 49.667, 48.232, fu, 2011-12-15 15:28:19+04, 2011-12-15 15:28:19+04, 3, 1)"}'::obj_special[], '{"(1, 3
SELECT horecami.insert_obj_common(
'{"(5, 2, LLLLL rest, 46181, a@a.com, ooo, kkk, 12:09, 20:40, 23, true, 49.667, 48.232, fu, 2011-12-15 15:28:19+04, 2011-12-15 15:28:19+04, 3, 1)"}'::obj_special[],
'{"(1, 3, q1, q2, q3, q4, qson latest, true, 2011-12-15 15:28:19+04, 2, 2, 3, 2011-12-15 15:28:19+04, ' || '{"(1, 1, 1, 1, 1)"}'::horecami.obj_soft_hardware[] || ')"}'::obj_soft[]
);
在这个过程中,有一个foreach循环可以正常工作。
但当我添加最后一个额外的参数作为数组(horecami.obj_soft_hardware[])时,它给了我格式错误的数组错误。
这是一个错误
ERROR: malformed array literal: "{"(1, 3, q1, q2, q3, q4, qson latest, true, 2011-12-15 15:28:19+04, 2, 2, 3, 2011-12-15 15:28:19+04, "
LINE 3: '{"(1, 3, q1, q2, q3, q4, qson latest, true, 2011-12-15 1...
^
DETAIL: Unexpected end of input.
SQL state: 22P02
Character: 202
它必须返回数字
我猜这是一个语法错误。
感谢您。您没有多维数组;您得到了一个包含复合类型的数组,而该数组又包含一个包含复合类型的数组 当将其作为字符串文字写入时,某些字符必须转义(例如,带空格的字符串需要引号,而那些引号需要转义)。然后在嵌套级别,它们都需要双引号和转义 要确定字符串文字应该是什么样子,只需使用实际数组和行(或复合类型)创建它,然后转换为文本,以获得所有字段都正确引用和转义的文字字符串值:
SELECT ARRAY[ROW(1, 3, 'q1', 'q2', 'q3', 'q4', 'qson latest', ARRAY[ROW(1, 1, 1, 1, 1)])]::TEXT
返回:
{"(1,3,q1,q2,q3,q4,\"qson latest\",\"{\"\"(1,1,1,1,1)\"\"}\")"}
非常感谢你