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掉

相關文章
相關標籤/搜索