postgresql|数据库|序列Sequence的创建和管理

前言:

Sequence也是postgresql数据库里的一种对象,其属性如同索引一样,但通常Sequence是配合主键来工作的,这一点不同于MySQL,MySQL的主键自增仅仅是主键的属性做一个更改,而postgresql的主键自增是需要序列这个对象来配合的,也就是说,如果仅仅创建了一个序列,但此序列没有和任何主键对象绑定,那么,这个序列并没有什么实际的意义,这一点一定要注意。

当然了,postgresql里面的序列因为是一个对象,因此,在数据库开发中是非常的方便的,比起MySQL要先进很多的哦。

那么,下面就序列的增删改查和序列的管理这些问题做一个简单的介绍。

一,

查看序列和序列的属性

查看序列 短命令 \ds

bash 复制代码
postgres=# \ds
          List of relations
 Schema | Name |   Type   |  Owner   
--------+------+----------+----------
 public | test | sequence | postgres
(1 row)

查看序列的属性详情:

  • 此序列是一个大数字类型的序列,也就是纯数字
  • 初始值是1,也就是start这一列
  • 步长是 1 , 也就是 Increment 这一列
  • 最大值是92233、、、、、、 你们自己数吧
  • 如果达到最大值后,此序列是否循环从1开始再次自增? 也就是cycles这一列 ,答案是否 ,no嘛,
  • 缓存数值,一般设置为1,这个无需更改
bash 复制代码
postgres=# \d test
                            Sequence "public.test"
  Type  | Start | Minimum |       Maximum       | Increment | Cycles? | Cache 
--------+-------+---------+---------------------+-----------+---------+-------
 bigint |     1 |       1 | 9223372036854775807 |         1 | no      |     1

此序列是否被绑定到某个表的主键:

查询该序列是否有值,可以看到,并没有,报错,还没有被定义在此会话期间,其实此序列我们也可以称它为孤儿序列

bash 复制代码
postgres=# select currval('test');
ERROR:  currval of sequence "test" is not yet defined in this session

运行以下命令查询所有的孤儿序列:

bash 复制代码
SELECT ns.nspname  AS schema_name
      ,seq.relname AS seq_name
  FROM pg_class AS seq
  JOIN pg_namespace ns
    ON (seq.relnamespace = ns.oid)
 WHERE seq.relkind = 'S'
   AND NOT EXISTS (SELECT *
          FROM pg_depend
         WHERE objid = seq.oid
           AND deptype = 'a')
 ORDER BY seq.relname;

输出如下:

如果绑定了某个表的主键,那么删除的时候会报错,报错信息里会提示依赖于哪个表,后面介绍删除的时候在详细说明。

二,

创建序列和绑定序列到某个表的某个主键

这里分为两种情况,第一种是已有序列的绑定,第二种是新建序列后绑定到某个表的某个主键

告个假,明天在更新剩余部分~~~主要是夜深了~~~~ 未完待续~~~~~!!!!!!!

相关推荐
BJ_Bonree7 小时前
Bonree ONE 发布直通车| 如何利用核心链路,快速排查定位系统故障?
大数据·运维·人工智能
颜颜yan_7 小时前
DevUI自定义开发实践:从零开始构建自定义组件和插件
android·java·数据库
编织幻境的妖7 小时前
数据库隔离级别详解与选择
数据库
wljt7 小时前
达梦导入大数据
数据库
q27551300427 小时前
PL27A1对拷线搭配 PTCB818A 设计资料 高速跨系统互传+键鼠共享一缆搞定
经验分享·单片机·嵌入式硬件·硬件架构·信号处理
科士威传动7 小时前
微型导轨的类型性能差异与场景适配需求
大数据·运维·人工智能·科技·机器人·自动化
马克学长7 小时前
SSM物流系统h7fel(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·ssm框架·物流管理系统
一颗宁檬不酸7 小时前
Oracle序列从2开始而不是从1开始的常见原因及解决方法
数据库·oracle
VX:Fegn08957 小时前
计算机毕业设计|基于springboot + vue健身房管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
Leon-Ning Liu7 小时前
Oracle 19c RAC ASM 密码文件恢复方案三:将补丁升级至 19.8 版本后,利用 asmcmd --nocp credfix 进行修复
数据库·oracle