Как указал Крис, в PostgreSQL это не проблема - любой базовый тип (например, int, text) имеет свой собственный подтип массива, и вы также можете создавать собственные типы, в том числе составные. Например:
CREATE TYPE test as (
n int4,
m int4
);
Теперь вы можете легко создать массив тестов:
select ARRAY[
row(1,2)::test,
row(3,4)::test,
row(5,6)::test
];
Вы можете написать функцию, которая будет умножать n * m для каждого элемента в массиве и возвращать сумму произведений:
CREATE OR REPLACE FUNCTION test_test(IN work_array test[]) RETURNS INT4 as $$
DECLARE
i INT4;
result INT4 := 0;
BEGIN
FOR i IN SELECT generate_subscripts( work_array, 1 ) LOOP
result := result + work_array[i].n * work_array[i].m;
END LOOP;
RETURN result;
END;
$$ language plpgsql;
и запустите его:
# SELECT test_test(
ARRAY[
row(1, 2)::test,
row(3,4)::test,
row(5,6)::test
]
);
test_test
-----------
44
(1 row)