以前一直用的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掉