postgresql-建立主键自增的表

以前一直用的mysql,这个也基本上是主流,主键自增是不少建表规范中的硬性要求,不过这两种数据库主键自增的区别仍是很大的mysql

一般navicat中对mysql 主键自增直接客户端指定便可,不过对PG貌似不支持客户端指定,因此须要执行一下sqlsql

若是还没有建立表,可用以下方法数据库

方法一:table

create table test_a (test

  id serial,
  name character varying(128),
  constraint pk_test_a_id primary key( id)
);方法

方法二:im

create table test_b(next

  id serial PRIMARY KEY,
  name character varying(128)
); 数据

这两种方法用的是pg的serial类型实现自增,drop表的时候指定的序列也会drop掉客户端

方法三:先建立主键表

create table test_c (

  id integer PRIMARY KEY,
  name character varying(128)
);  

再手动建立序列

CREATE SEQUENCE test_c_id_seq
START WITH 1
INCREMENT BY 1
NO MINVALUE
NO MAXVALUE
CACHE 1;

将序列赋值给主键
alter table test_c alter column id set default nextval('test_c_id_seq');

这种方法在drop表的时候序列不会随着drop掉

相关文章
相关标签/搜索