健康一贴灵,专注医药行业管理信息化

转: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掉
复制代码

 

posted @   一贴灵  阅读(229)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
学以致用,效率第一
点击右上角即可分享
微信分享提示