文章目录
- 一、 准备工作
- 二、 创建序列达到自增的效果
- 1. 创建序列
- 2. 序列的相关方法
- 3. 插入数据
- 4. 设置默认值
- 三、使用SERIAL
- 1. 建表语句
- 2. 插入数据
以前建立自增主键都是用mysql建的,只要写个 auto_increment就行了,最近因为工作,需要用到PostgreSQL的自增主键,就去了解了下。发现网上的这点东西写的真乱…就没有个说是整整齐齐从头到尾说清楚的,没有就只能我自己写了…
首先,pgsql没有auto_increment这么一说,所以想要建立自增主键就得想想其他办法了
一、 准备工作
首先创建一张表:
1 2 3 4 | create table test( id int primary key, age int ) |
二、 创建序列达到自增的效果
1. 创建序列
pgsql里,有种东西叫自增,很像mysql里的约束。建立一个自增的序列,每次需要获取自增主键时,调用一下这个序列就可以了。
建立自增主键的序列的语法:
1 2 3 4 5 6 7 | 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 : 可以直接指定一个表的字段,也可以不指定。
需要自增主键的时候,调用
1 2 3 4 | test=# select nextval('test_id_seq'); nextval --------- 1 |
2. 序列的相关方法
相关的方法如下:
函 数 | 返 回 类 型 | 描 述 |
---|---|---|
currval( regclass ) | bigint | 获取指定序列最近一次使用netxval后的数值,如果没有使用nextval而直接使用currval会出错。 |
lastval() | bigint | 返回最近一次用 nextval 获取的任意序列的数值 |
nextval( regclass ) | bigint | 递增序列并返回新值 |
setval( regclass,bigint ) | bigint | 设置序列的当前数值 |
setval( regclass,bigint ,boolean ) | bigint | 设置序列的当前数值以及 is_called 标志,如果为true则立即生效,如果为false,则调用一次nextval后才会生效 |
需要什么值就去找具体的函数就行了。
3. 插入数据
假设现在要向test表中插入数据,id自增,则:
1 2 3 | insert into test values( nextval('test_id_seq') , 1 ) |
但是这种操作,每次都得写一遍序列名,很烦。不过有办法解决。看下面:
4. 设置默认值
可以设置id字段的默认值为
1 2 3 4 5 6 7 | alter table test -- 表名 alter column id -- 列名 set default nextval( 'test_id_seq' -- 序列名 ); |
再向test表中插入数据,这样写就行了:
1 | insert into test(age) values(12) |
或者直接:
1 | insert into test values(12) |
三、使用SERIAL
1. 建表语句
使用serial时,建表语句需要改一下:
1 2 3 4 | create table test( id serial primary key, age int ) |
这时候,会自动创建名为
例如,建立上表以后,则自动创建出名为
2. 插入数据
插入数据,这样写就行了:
1 | insert into test(age) values(12) |
或者直接:
1 | insert into test values(12) |