我将在Vertica数据库中创建一些表,我必须在其中给出全局唯一标识符以唯一地标识每一行。请建议怎么做?
答案 0 :(得分:0)
请参阅documentation:
增量值对象的类型
答案 1 :(得分:0)
您正在寻找命名序列。您可以对多个表使用相同的序列:
-- 2 tables...
CREATE TABLE tst (id INT, value varchar(10));
CREATE TABLE tst2 (id INT, value varchar(10));
-- 1 sequence...
CREATE SEQUENCE tst_seq;
-- ... said sequence is used by both tables
ALTER TABLE tst ALTER COLUMN id set default NEXTVAL('tst_seq');
ALTER TABLE tst2 ALTER COLUMN id set default NEXTVAL('tst_seq');
-- testing...
INSERT INTO tst (value) VALUES ('tst');
INSERT INTO tst2 (value) VALUES ('tst2');
-- success!
=> SELECT * FROM tst;
id | value
----+---------
1 | tst
(1 row)
=> SELECT * FROM tst2;
id | value
----+----------
2 | tst2
(1 row)
然后在表创建过程中使用的NEXTVAL('named_sequence')
相当于您要查找的NEWID()
。