之前一直用的mysql,這個也基本上是主流,主鍵自增是很多建表規范中的硬性要求,不過這兩種數據庫主鍵自增的區別還是很大的
通常navicat中對mysql 主鍵自增直接客戶端指定即可,不過對PG貌似不支持客戶端指定,所以需要執行一下sql
如果尚未創建表,可用如下方法
方法一:
create table test_a (
id serial,
name character varying(128),
constraint pk_test_a_id primary key( id)
);
方法二:
create table test_b(
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掉
