PostgreSQL建立自增主键的两种方法

打印 上一主题 下一主题

主题 510|帖子 510|积分 1530

一、 预备工作

首先创建一张表:
  1. create table test(
  2.         id int primary key,
  3.         age int
  4. )
复制代码
二、 第一种方法----创建序列达到自增的结果

1. 创建序列

pgsql里,有种东西叫自增,很像mysql里的约束。建立一个自增的序列,每次必要获取自增主键时,调用一下这个序列就可以了。建立自增主键的序列的语法:
  1. CREATE SEQUENCE
  2. test_id_seq
  3. INCREMENT 1
  4. MINVALUE 1
  5. MAXVALUE 9223372036854775807
  6. START WITH 1
  7. CACHE 1;
复制代码

  • INCREMENT BY : 每次序列增加(或镌汰)的步长
  • MINVALUE : 序列最小值,NO MINVALUE体现没有最小值
  • MAXVALUE : 序列最大值,NO MAXVALUE体现没有最大值
  • START WITH :以什么序列值开始
  • CYCLE : 序列是否循环利用
  • OWNED BY : 可以直接指定一个表的字段,也可以不指定。
必要自增主键的时间,调用nextval(序列名)就可以了:
  1. test=#  select nextval('test_id_seq');
  2. nextval
  3. ---------
  4. 1
复制代码
2. 序列的相干方法

相干的方法如下(regclass 体现序列的名称):
函数返回范例描述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. insert into test values(
  2.         nextval('test_id_seq') , 1
  3. )
复制代码
但是这种操作,每次都得写一遍序列名,很烦。不过有办法解决。看下面:
4. 设置默认值

可以设置id字段的默认值为nextval(‘test_id_seq’),如许插入数据就不用每次都写一遍了。
  1. alter table
  2.         test -- 表名
  3. alter column
  4.         id -- 列名
  5. set default nextval(
  6.         'test_id_seq'  -- 序列名
  7. );
复制代码
再向test表中插入数据,如许写就行了:
  1. insert into test(age) values(12)
复制代码
大概直接:
  1. insert into test values(12)
复制代码
三、第二种方法----利用SERIAL

1. 建表语句

利用serial时,建表语句必要改一下:
  1. create table test(
  2.         id serial primary key,
  3.         age int
  4. )
复制代码
这时间,会主动创建名为表名_字段名_seq的序列,且MAXVALUE=9223372036854775807,其余值为1。
例如,建立上表以后,则主动创建出名为test_id_seq的序列。
2. 插入数据

插入数据,如许写就行了:
  1. insert into test(age) values(12)
复制代码
大概直接:
  1. insert into test values(12)
复制代码
3. 如何获取序列的当前值

利用如下sql可以获取序列当前值:
  1. select currval('test_id_seq')
复制代码
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

立聪堂德州十三局店

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表