我有一个包含 TEXT 数组的复合类型等。我在主表中使用它来创建一个复合类型数组。
如何生成 INSERT 命令(不使用复合类型的默认字段名称)?我可以使用复合数组创建一个 TEMPORARY TABLE,然后将其插入到主表中吗?
例如:
DROP TABLE collection;
DROP TABLE book_set;
DROP TYPE book;
CREATE TYPE book AS ( title TEXT, authors TEXT[], extra_spare TEXT );
CREATE TEMPORARY TABLE book_set ( books book[] );
CREATE TABLE shelf_collection ( shelf INT, position INT, books book[] );
-- Prefer to specify the fields I want, and NOT extra_spare as shown here!
-- AND it doesn't yet work... needs more casting?
INSERT INTO book_set( books ) VALUES (
( 'book1', array[ ( 'author1', 'author2' ) ], '' ),
( 'book2', array[ ( 'author3' ) ], '' ) );
-- And this obviously does not work yet!
INSERT INTO shelf_collection( shelf, position, books ) VALUES ( 1, 2, book_set );
第一个 INSERT 失败并显示以下消息:
错误:INSERT 的表达式多于目标列。
有或没有 array[] 构造都失败。
我的实际使用要复杂得多,复合材料包含其他复合材料和许多领域。
出于性能原因(不需要连接来检索),我在这里没有使用多个表,并且内部组合和数组从不独立引用。
我正在使用perl(5.14.2)
和。DBI(1.616)
psql(9.1.7)
更多信息:
以下工作,但我如何更改它,以便我不需要指定书籍的所有字段:
DROP TABLE shelf_collection;
DROP TYPE book;
CREATE TYPE book AS ( title TEXT, authors TEXT[], extra_spare TEXT );
CREATE TABLE shelf_collection ( shelf INT, position INT, books book[] );
INSERT INTO shelf_collection VALUES ( 12, 23, array[ROW( 'book title 1', array[ 'author1', 'author2' ], '' )::book] );
SELECT * FROM shelf_collection;