PostgreSQL如何为主键创建自增序列(Sequences)

2023-05-16

引言

在持久层框架如Hibernate(JPA)、Mybatis中经常会用到Sequences(函数)去创建主键值,
PostgreSQL中,用serial数据类型的主键,数据库会自动创建Sequences,
那么我们自己设置的integer主键,如何设置添加Sequences呢?

目录

  • 引言
  • 目录
  • 一测试环境
      • pgadmin4 点我查看如何安装
      • psql PostgreSQL 965
      • 结构图
  • 二创建表
      • 表名 mytable
      • 主键名 myid
      • 模式名 gys
      • 用户名 postgres
      • SQL
  • 三创建Sequences
      • Sequences 名称 mytable_myid_seq
      • 主键名 myid
      • 模式名 gys
    • 图形pgadmin管理
    • SQL创建
      • SQL
  • 四为主键设置Sequences
  • 五测试Sequences函数
  • 参考资料
  • 附录序列函数

一.测试环境:

1. pgadmin4 <点我查看如何安装>

(没有pgadmin4,请用命令行+SQL代替)

2. psql (PostgreSQL) 9.6.5

3. 结构图:

这里写图片描述

二.创建表:

1.表名 mytable

2.主键名 myid

3.模式名 gys

4.用户名 postgres

测试数据库中,创建表:(gys 是模式名,类似namespace,默认是public)

SQL:

CREATE TABLE gys.mytable
(
    myid integer NOT NULL,
    PRIMARY KEY (myid)
)
WITH (
    OIDS = FALSE
);

ALTER TABLE gys.mytable
    OWNER to postgres;

三.创建Sequences:

1. Sequences 名称 mytable_myid_seq

2.主键名 myid

3.模式名 gys

图形pgadmin管理:

在pgadmin中,我们可以在sequences上右键,create -> sequences
如图:
Step 1.
这里写图片描述

Step 2.
这里写图片描述

Step 3.

这里写图片描述

详细参数1

OK了,生成的SQL:

CREATE SEQUENCE gys.mytable_myid_seq
    INCREMENT 1
    START 1
    MINVALUE 1
    MAXVALUE 99999999
    CACHE 1;

ALTER SEQUENCE gys.mytable_myid_seq
    OWNER TO postgres;

这里写图片描述

SQL创建:

语法:

CREATE [ TEMPORARY | TEMP ] SEQUENCE name [ INCREMENT [ BY ] increment ]
    [ MINVALUE minvalue | NO MINVALUE ] [ MAXVALUE maxvalue | NO MAXVALUE ]
    [ START [ WITH ] start ] [ CACHE cache ] [ [ NO ] CYCLE ]

SQL:

CREATE SEQUENCE gys.mytable_myid_seq
    INCREMENT 1
    START 1
    NO MINVALUE
    NO MAXVALUE
    CACHE 2;

四.为主键设置Sequences:

执行SQL:

alter table gys.mytable alter column myid set default nextval('gys.mytable_myid_seq');

五.测试Sequences函数:

所有序列函数参见”附录:序列函数

SELECT nextval('gys.mytable_myid_seq');

这里写图片描述

INSERT INTO gys.mytable VALUES (nextval('gys.mytable_myid_seq'));
SELECT myid FROM gys.mytable;

这里写图片描述

参考资料:

https://www.postgresql.org/docs/8.1/static/sql-createsequence.html

https://www.postgresql.org/docs/9.1/static/functions-sequence.html

http://www.cnblogs.com/mchina/archive/2013/04/10/3012493.html

http://francs3.blog.163.com/blog/static/40576727201111715035318/

http://www.cnblogs.com/nirvana7/archive/2011/12/27/2303673.html

附录:序列函数

函数返回类型描述
nextval(regclass)bigint递增序列对象到它的下一个数值并且返回该值。这个动作是自动完成的。即使多个会话并发运行nextval,每个进程也会安全地收到一个唯一的序列值。
currval(regclass)bigint在当前会话中返回最近一次nextval抓到的该序列的数值。(如果在本会话中从未在该序列上调用过 nextval,那么会报告一个错误。)请注意因为此函数返回一个会话范围的数值,而且也能给出一个可预计的结果,因此可以用于判断其它会话是否执行过nextval。
lastval()bigint返回当前会话里最近一次nextval返回的数值。这个函数等效于currval,只是它不用序列名为参数,它抓取当前会话里面最近一次nextval使用的序列。如果当前会话还没有调用过nextval,那么调用lastval将会报错。
setval(regclass, bigint)bigint重置序列对象的计数器数值。设置序列的last_value字段为指定数值并且将其is_called字段设置为true,表示下一次nextval将在返回数值之前递增该序列。
setval(regclass, bigint, boolean)bigint重置序列对象的计数器数值。功能等同于上面的setval函数,只是is_called可以设置为true或false。如果将其设置为false,那么下一次nextval将返回该数值,随后的nextval才开始递增该序列。

  1. 参数见:https://www.postgresql.org/docs/8.1/static/sql-createsequence.html ↩
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

PostgreSQL如何为主键创建自增序列(Sequences) 的相关文章

  • 线程同步(互斥锁与信号量的作用与区别)

    信号量用在多线程多任务同步的 xff0c 一个线程完成了某一个动作就通过信号量告诉别的线程 xff0c 别的线程再进行某些动作 xff08 大家都在semtake的时候 xff0c 就阻塞在 哪里 xff09 而互斥锁是用在多线程多任务互斥
  • 误解程序运行(从单片机到开始)

    误解程序运行 从单片机到开始 关于程序的执行 xff0c 以前想的不多 xff0c 没有意识到一个程序在运行时 xff0c 从哪里读指令 xff0c 数据又写在哪里 最近在看CSAPP时这个念头经常在脑袋中晃荡 从单片机上知道 xff0c
  • Out-of-Bounds Memory References and Buffer Overflow

    callee pushl edp save edp on stack movl esp edp pushl ebx save ebx subl 20 esp popl ebx restore ebx popl edp restore
  • 嘉立创专业板stm32拓展板十分钟快速入门

    本文是为不想深入学PCB但是迫不得已需要用PCB的人或者想要做一个32的拓展版的童鞋们的快速入门并做出板子的博客 xff0c 因此 xff0c 本文内容不会深入讨论元件 xff0c 只会教授基础流程 xff0c 并且没有画芯片 本文内容 x
  • 电子信息工程四年学习之思

    毕业后 xff0c 回顾四年学习历程发现 xff0c 当时以为的明白 xff0c 到现在都是那时的不明白 或许是自己的经历 xff08 参加比赛比较多 xff09 导致了现在的反思 但是 xff0c 回顾那个时候的课程设置 xff0c 却都
  • 将要到来的三大技术革命与联系

    http www csdn net article 2013 02 14 2814128 2013大数据 http www csdn net article 2013 02 15 2814135 bigdata is coming 大数据
  • Keil的常见编译警告

    1 warning 767 D conversion from pointer to smaller integer 解释 xff1a 将指针转换为较小的整数 影响 xff1a 可能造成的影响 xff1a 容易引起数据截断 xff0c 造成
  • 《大数据时代》之后

    现在想想也不记得当时是怎么找到 大数据时代 这本书的 xff0c 好像是在查找数据库方面的书 xff0c 看到亚马逊推荐的书里有这本 xff0c 发现最近才出版的就买一本回来看看 然而这个过程中 xff0c 其实自己已经得到了大数据带来的影
  • 《代码大全》笔记

    最近将去年毕业时 xff0c 大神推荐的 代码大全 看完了 xff08 已经过去一年了 xff0c 要十分感谢推荐 xff0c 还有凤林兄的 深入理解计算机系统 xff09 零零碎碎的时间 xff0c 发现很多东西虽然在书中标记了 xff0
  • 《编程精粹》思之代码与产品

    之前眼中有代码无产品 xff0c 现在眼中有产品有代码 xff0c 什么时候能做到有产品无代码 xff1f 还需要努力 刚开始实习的时候 xff0c 总喜欢在程序中使用 p 43 1 61 而不是p 1 来给入参 xff0c 甚至于用来给定
  • 树莓派4B+Intel神经计算棒(Stick2)+YoloV5可行性考察报告

    1 神经棒只能作为协处理器 在执行脚本时 xff0c 通过在命令后面加上 d 设备名 就可以指定硬件设备来加速推理 例如 命令行指定神经棒运行 demo squeezenet download convert run span class
  • 在Vue中获取v-for的index值

    lt el submenu index 61 34 item id 43 39 39 34 v for 61 34 item index in menuList 34 key 61 34 item id 34 gt lt template
  • 死区时间的分析与设置

    出现死区的主要原因是因为MOS管的源极和栅极之间的结电容 现在在栅极加上一个门电路 当门电路输出的信号跳变的瞬间 xff0c 电流是非常大的 xff0c 会导致MOS管发热 xff0c 所以需要在门电路后面再串联一个电阻 xff0c 这个电
  • MOS管特性和导通过程

    三极管是流控流器件 xff0c 它不能驱动功率太大的器件 xff0c 因为此时C极电流大 xff0c 而CE压降为0 3V左右 xff0c 在三极管上面消耗的功率就很大 xff0c 还容易发热 所以压控压型的MOS管就诞生了 特性 一开始给
  • 2014欢聚时代(YY)软件研发笔试题

    本文转载自 xff1a http blog csdn net arcsinsin article details 12714027
  • FOC 单电阻采样 位置环控制伺服电机

    最近在做微型伺服电机的控制 xff0c 需要平滑地将电机定位到某个位置 伺服电机 编码器 PCB都是自制的 这里我把整个的流程和遇到的问题记录一下 目录 硬件设计 STM32CubeMX配置 程序设计 测试遇到的问题 演示视频 硬件设计 这
  • C语言正余弦函数定点查表算法原理及实现

    如果用数学库中的sin和cos函数计算 xff0c 可能涉及浮点 乘法 除法运算 xff0c 运行速率较低 这里介绍一种正余弦查表算法 参考代码 xff1a SMT32 FOC电机库的mc math c 首先我们知道正弦和余弦的函数值差了9
  • Git合并操作之merge、rebase、squash详解

    文章目录 1 git merge和git rebase1 1 git merge1 2 git rebase1 2 1 rebase交互模式1 2 2 git pull rebase 2 git squash 有时在一个分支上完成一个功能的
  • QT 右键菜单栏的实现

    有时我们希望在窗口中右键弹出菜单 xff0c 这里来介绍一下QT中怎么实现 xff0c 首先创建一个MainWindow项目 1 在mainwindow h文件中添加槽声明 private slots void on MainWindow
  • 基于Cortex-M的RTOS上下文切换详解及FreeRTOS实例

    文章目录 1 Cortex M MCU特性 1 1 操作模式 1 2 寄存器 1 2 1 核心寄存器 1 2 2 浮点寄存器 Floating Point registers 1 2 3 特殊寄存器 Special Registers 1

随机推荐