zoukankan      html  css  js  c++  java
  • 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掉

  • 相关阅读:
    环境部署:Linux下查看JDK安装路径
    环境部署(一):Linux下安装JDK
    linux常见命令
    设计用例
    测试用例的优先级
    快速幂和快速乘
    docker-compose安装
    jmeter通过命令生成自动测试报告
    jmeter环境变量配置
    java将毫秒转化为当前时间
  • 原文地址:https://www.cnblogs.com/yb38156/p/10024534.html
Copyright © 2011-2022 走看看