PostgreSQL --序列与自增id的秘密
admin
2023-05-11 07:02:14
0

一、PostgreSQL的自增id serial

1.2、serial的本质

我们在创建表时,经常需要使用到自增id,往往这么写,

create table test (
    id serial,  #使用serial来创建一个自增id
    name varchar(64) not null
    )
    通过serial创建自增id,同时会创建属于这个表的自增序列,并将id字段设置为not null

serial和bigserial类型不是真正的类型,只是为在表中设置唯一标识做的概念上的便利,本质上是创建了一个序列发生器,然后把自增字段的默认值设置为这个序列发生器的nextval

CREATE TABLE tablename (
    colname SERIAL
);
等价于
CREATE SEQUENCE tablename_colname_seq;
CREATE TABLE tablename(
    colname integer DEFAULT nextval('tablename_colname_seq') NOT NULL
);

1.2、序列的属性

postgres=# \d+ test5_id_seq 
         Sequence "public.test5_id_seq"
Column     |  Type   |        Value        | Storage 
---------------+---------+---------------------+---------
 sequence_name | name    | test5_id_seq        | plain
 last_value    | bigint  | 1                   | plain
 start_value   | bigint  | 1                   | plain    #序列起始值
 increment_by  | bigint  | 1                   | plain     #每次递增值
 max_value     | bigint  | 9223372036854775807 | plain        #最大值
 min_value     | bigint  | 1                   | plain       #最小值
 cache_value   | bigint  | 1                   | plain     
 log_cnt       | bigint  | 0                   | plain 
 is_cycled     | boolean | f                   | plain   #是否循环
 is_called     | boolean | f                   | plain
Owned by: public.test5.id

因为自增本质上是取序列发生器的下一个值,所以可以多个表共用一个序列发生器,可以实现多表唯一值,当然,还可以设置序列是否可循环来实现id循环
例如:
PostgreSQL --序列与自增id的秘密

 

二、序列

2.1创建序列

CREATE SEQUENCE name increment by 1 maxvalue 10 minvalue 1 start 1 cycle

2.2、序列操作

下一个值:nextval(regclass)
当前值:currval(regclass)
设置值:setval(regclass)

2.3、将序列绑定到表

create table test_seq (
    id int not null default nextval('my_seq1'), 
    name varchar(64)
    )

相关内容

热门资讯

河南一企业每月给员工父母发“工... 近日,河南一企业每月1日给员工父母发“工资”一事在网上引热议,很多人点赞,更多也是好奇:咋发?发多少...
“90后夫妻同患罕见病瘫痪”引... 近日,一段“90后新婚夫妻同患罕见病瘫痪”的视频在网上流传,引发关注和热议。有网友对夫妻俩的遭遇表示...
北京:每年开放场景空间资源和场... 5月13日,北京市发展改革委、北京市科委、中关村管委会等部门联合发布了《北京市加快推动场景培育和开放...
DAA衡量智能体的时代,云服务... 今年以来,国内外头部云厂商相继上调部分核心产品价格,打破了行业近二十年“只降不升”的惯例。这背后,是...
2026年网络发稿平台权威测评... 引言:数字化浪潮下,网络发稿生态正在经历深刻变革 在信息爆炸的互联网时代,网络空间已成为企业品牌传播...
“小皮球,架脚踢,马兰开花二十... “二八二五六,二八二五七,二八二九三十一……”当短视频里的外国网友惊呼“这是什么暗号”时,有网友笑称...
房子重新装修需要多少钱(房子重... 像新房子装修后的使用寿命大概在15到20年的样子,之后的各种材料都因时间的关系会逐渐老化,看着越来越...
不锈钢橱柜多少一米 具体要看你使用的不锈钢是哪种型号的,因为市面上有很多种型号的不锈钢,当然价钱也有所不同。那么我们普通...
300-300的瓷砖是多少平方 我们在计算平方的时候,都是将长度乘以宽度,所以300×300的瓷砖,这些瓷砖的面积肯定是0.9个平方...
热水器是一直开着省电还是现用现... 一般情况下家用的热水器是现用现烧比较省电,当热水器一直开着时,热水器会一直持续进行烧水工作,这样会比...