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