目录
- 一、 准备工作
- 二、 第一种方法—-创建序列达到自增的效果
- 1. 创建序列
- 2. 序列的相关方法
- 3. 插入数据
- 4. 设置默认值
- 三、第二种方法—-使用SERIAL
- 1. 建表语句
- 2. 插入数据
- 3. 如何获取序列的当前值
- 总结
一、 准备工作
首先创建一张表:
create table test(
id int primary key,
age int
)
二、 第一种方法—-创建序列达到自增的效果
1. 创建序列
pgsql里,有种东西叫自增,很像mysql里的约束。建立一个自增的序列,每次需要获取自增主键时,调用一下这个序列就可以了。建立自增主键的序列的语法:
CREATE SEQUENCE
test_id_seq
INCREMENT 1
MINVALUE 1
MAXVALUE 9223372036854775807
START WITH 1
CACHE 1;
- INCREMENT BY : 每次序列增加(或减少)的步长
- MINVALUE : 序列最小值,NO MINVALUE表示没有最小值
- MAXVALUE : 序列最大值,NO MAXVALUE表示没有最大值
- START WITH :以什么序列值开始
- CYCLE : 序列是否循环使用
- OWNED BY : 可以直接指定一个表的字段,也可以不指定。
需要自增主键的时候,调用nextval(序列名)就可以了:
test=# select nextval(\’test_id_seq\’);
nextval
———
1
2. 序列的相关方法
相关的方法如下(regclass 表示序列的名称):
需要什么值就去找具体的函数就行了。
3. 插入数据
假设现在要向test表中插入数据,id自增,则:
insert into test values(
nextval(\’test_id_seq\’) , 1
)
但是这种操作,每次都得写一遍序列名,很烦。不过有办法解决。看下面:
4. 设置默认值
可以设置id字段的默认值为nextval(‘test_id_seq’),这样插入数据就不用每次都写一遍了。
alter table
test — 表名
alter column
id — 列名
set default nextval(
\’test_id_seq\’ — 序列名
);
再向test表中插入数据,这样写就行了:
insert into test(age) values(12)
或者直接:
insert into test values(12)
三、第二种方法—-使用SERIAL
1. 建表语句
使用serial时,建表语句需要改一下:
create table test(
id serial primary key,
age int
)
这时候,会自动创建名为表名_字段名_seq的序列,且MAXVALUE=9223372036854775807,其余值为1。
例如,建立上表以后,则自动创建出名为test_id_seq的序列。
2. 插入数据
插入数据,这样写就行了:
insert into test(age) values(12)
或者直接:
insert into test values(12)
3. 如何获取序列的当前值
使用如下sql可以获取序列当前值:
select currval(\’test_id_seq\’)
总结
到此这篇关于PostgreSQL建立自增主键的2种方法的文章就介绍到这了,更多相关PostgreSQL建立自增主键内容请搜索悠久资源以前的文章或继续浏览下面的相关文章希望大家以后多多支持悠久资源!