postgresql-創建主鍵自增的表


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


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM