postgre中的复合类型

声明复合类型

Composite Types:复合类型Composite Types表示行或记录的结构; 它本质上只是一个字段名称及其数据类型。 PostgreSQL 允许复合类型像用简单类型相同的方式使用。 例如,表的列可以声明为复合类型。 语法与 CREATE TABLE 相当,只是可以指定字段名称和类型; 目前不能包含任何约束(例如 NOT NULL)。 请注意,AS 关键字是必不可少的; 没有它,系统会认为有一种不同的 CREATE TYPE 命令,你会得到奇怪的语法错误。 以下是定义复合类型的两个简单示例:

CREATE TYPE complex AS (
    r       double precision,
    i       double precision
);

CREATE TYPE inventory_item AS (
    name            text,
    supplier_id     integer,
    price           numeric
);

定义了类型后,我们可以使用它们:

CREATE TABLE on_hand (
    item      inventory_item,
    count     integer
);

INSERT INTO on_hand VALUES (ROW('fuzzy dice', 42, 1.99), 1000);


CREATE FUNCTION price_extension(inventory_item, integer) RETURNS numeric
AS 'SELECT $1.price * $2' LANGUAGE SQL;

SELECT price_extension(item, 10) FROM on_hand;

每当您创建表时,也会自动创建一个复合类型,其名称与表的名称相同,以表示表的行类型。

CREATE TABLE inventory_item (
    name            text,
    supplier_id     integer REFERENCES suppliers,
    price           numeric CHECK (price > 0)
);

给复合类型赋值

要将复合值写为文字常量,将字段值括在括号内并用逗号分隔。 如果它包含逗号或括号,需要在任何字段值周围加上双引号。要使字段为 NULL,请在列表中的位置不写任何字符,如果您想要一个空字符串而不是 NULL,请写双引号.

'( val1 , val2 , ... )'
'("fuzzy dice",42,1.99)'
'("fuzzy dice",42,)'
'("",42,)'

ROW 表达式语法也可用于构造复合值,只要表达式中有多个字段,ROW 关键字实际上是可选的,因此可以简化为:

ROW('fuzzy dice', 42, 1.99)
ROW('', 42, NULL)

('fuzzy dice', 42, 1.99)
('', 42, NULL)