PostgreSQL中三种自增列sequence,serial,identity区别
这三个对象都可以实现自增,这里从如下几个维度来看看这几个对象有哪些不同,其中功能性上看,大部分特性都是一致的或者类似的。 1,sequence在所有数据库中的性质都一样,它是跟具体的字段不是强绑定的,其特点是支持多个对个对象之间共享。 sequence作为自增字段值的时候,对表的写入需要另外单独授权sequence(GRANT USAGE ON SEQUENCE test_old_id_seq;) sequence类型的字段表,在使用CREATE TABLE new_table LIKE old_table的时候,新表的自增字段会已久指向原始表的sequence 结论:对于自增字段,无特殊需求的情况下,sequence不适合作为“自增列”,作为最最次选。 2,identity本质是为了兼容标准sql中的语法而新加的,修复了一些serial的缺陷,比如无法通过alter table的方式实现增加或者删除serial字段 2.1 identity定义成generated by default as identity也允许显式插入, 2.2 identity定义成always as identity,加上overriding system value也可以显式不插入 结论:identity是serial的“增强版”,更适合作为“自增列”使用。 3,sequence