达梦数据库,数据库重置主键id从1开始

news2024/10/2 10:31:11

一、前言

今天中国国寿XX项目XC环境达梦遇到id主键自增顺序不对的问题,那么如何修改一个表的自增主键顺序呢?下边通过具体测试案例进行深入分析,通过delete/update/truncate/alter观察数据的变换总结出结论,欢迎各位喜欢达梦数据的爱国人士一起研究学习一下。

二、delete/update/truncate/alter分别进行测试

1、创建测试表及基础测试数据。

创建测试表

--创建测试表,定义id列自增
create table dmtest (id int IDENTITY(1,1) primary key,name varchar(10));
--插入测试数据并提交
set identity_insert dmtest on
insert  into  dmtest values(1,'张三'),(2,'李四'),(3,'王五');
commit;
set identity_insert dmtest off
--插入测试数据
insert  into  dmtest values('张三'),('李四'),('王五');
commit;

查看结果:

        可以看出,设置列为主键自增不能重复,不需要赋值插入,默认从1自增。对自增列赋值需要设置SET IDENTITY_INSERT为ON时,才能对自增列赋值。命令如下:set identity_insert 表名 on;

如果指定id序列后不在指定,后续ID键值会根据目前最大值+1递增,如下图:

 2、delete操作主键自增变化。

 由此可见,delete删除之后再insert,id列会按照删除之前最大值+1进行自增,如果指定id大小插入后再insert也会按照删除之前最大值+1进行自增,因此delete不会改变id自增属性。

3、update 操作主键自增变化。

 此时update修改会报错,提示:行附近出现错误[-2664]:试图修改自增列[ID].因此,update无法对自增列进行修改。

4、truncate  操作主键自增变化。

 truncate 表之后发现自增ID序列被重置,充实初始化到建表时状态,从1开始,步长为1进行自增。但是数据丢失了,如果数据量特别大,truncate之后再进行insert势必会造成时间上的浪费。

5、删除主键属性后再添加,操作主键自增变化

 删除主键自增属性后再添加,无法重置属性,仍然是按照最近一次修改的最大值+1自增。

三、总结

        通过相关测试结论如下:

  1. delete删除之后再insert,id列会按照删除之前最大值+1进行自增,如果指定id大小插入后再insert也会按照删除之前最大值+1进行自增,因此delete不会改变id自增属性。

  2. update无法对自增列进行修改。

  3.  truncate 表之后发现自增ID序列被重置,充实初始化到建表时状态,从1开始,步长为1进行自增,但是数据丢失了。

总之如下:

        清空表清空表数据,新增数据时,主键仍然从未删除之前的最后一条数据开始增加。
        截断表清空表数据,新增数据时,主键从1开始,相当于以下的两条SQL。

四、解决方案

1、通过truncate table进行自增属性初始化递增,恢复到建表初始状态。

2、在不删除数据情况下如何进行ID自增主键初始化排序,从1开始。

手动指定序列号非自增。如下图:

 不删除数据进行序列自增从1开始。

 alter table dmtest drop id;
 alter table dmtest add id int IDENTITY(1, 1) not null primary key;

 结果如下图:

        这个可以不删除数据,但是会发生一个问题,就是ID,NAME列的顺序发生了改变,而且达梦不像MySQL那样支持添加字段可以指定在某个字段的前后,即 before、after指定添加列的位置。可能后续版本会新增这个功能。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/7534.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

值得推荐的小型 C 语言开源项目:Triggerhappy

这几天在知乎上看到了一个好问题: 有哪些值得推荐的小型 C 语言开源项目? 题主很可能是想要一个这样的开源项目:功能小巧、代码质量高,可读性好,以便自己循序渐进地学习 C 语言。 作为一个嵌入式开发人员&#xff0…

趁年轻,大胆闯

趁年轻,大胆闯如果我是20岁,我会拿出未来的十年,全力已赴的赚钱,折腾,不要任何安全感。 出来创业,就是为100倍以上的赔率来的。

HTTPS

一、HTTPS是什么 HTTPS也是一个应用层协议,是在HTTP协议的基础上引入了一个加密层。 由于HTTP协议内容一般都是本文方式明文传输的,这就导致它在传输过程中会出现被篡改的情况。 经典案例就是万恶的“运营商劫持”! 除了运营商可以劫持&a…

如何快速从零开始搭建一个前端项目

2022 年了,如何快速从零开始搭建一个合适的前端项目? 准备工作 首先本地需要安装好 node 环境以及包管理工具,推荐直接使用 pnpm,也可以通过 pnpm 来直接管理 nodejs 版本。 pnpm 安装: # Mac or Linux curl -fsSL…

SpringMVC 环境配置

文章目录引入1、MVC的概念2、Spring MVC基本原理一、导入坐标(导包)导入Spring MVC所需要的jar包二、新建springmvc-config.xml文件三、配置web.xml四、 创建Controller五、配置SpringMVC配置文件六、配置页面其他引入 Spring Web MVC是一种基于Java的实…

cv算法工程师学习教程

前言一,计算机系统 1.1,计算机系统书籍1.2,设计模式教程 二,编程语言 2.1,C 学习资料2.2,Python 学习资料 三,数据结构与算法 3.1,数据结构与算法课程3.2,算法题解 四&am…

数字信号处理及python实现(三)

数字信号处理及python实现三抽样引起的混叠抽样的频域视图样本重建信号拟合正弦波线性与多项式内插理想低通滤波器这是参考知乎的数字信号处理及matlab实现的python实现版本,参考连接 上一期:数字信号处理及python实现(二) 项目文件结构 test为测试文件&#xff…

【Vue】Vue开发实战之我的笔记(ch18-ch27)--20221115

参考https://blog.csdn.net/yfm120750310/article/details/111353963 18 | 为什么需要Vuex 18.1 为什么需要Vuex provide和inject虽然能够实现层层传递的数据管理,但对于一个大的管理系统而言会显得有些繁琐,我们需要一个大型的状态管理系统。 Vuex不…

甘特图是什么?如何快速搭建?

甘特图是什么? 甘特图是一种条状图,直观展示项目进展随时间的走势及联系。其中,项目时间由横轴表示,项目活动由纵轴表示。整体线条表示整个项目期间内,计划和实际的活动完成情况。甘特图起初用于美国胡佛水坝和美国洲…

cpe(通用平台枚举)命名规范及python CPE库实战

大家好,我是爱编程的喵喵。双985硕士毕业,现担任全栈工程师一职,热衷于将数据思维应用到工作与生活中。从事机器学习以及相关的前后端开发工作。曾在阿里云、科大讯飞、CCF等比赛获得多次Top名次。喜欢通过博客创作的方式对所学的知识进行总结与归纳,不仅形成深入且独到的理…

一文看懂Linux 页表、大页与透明大页

一、 内存映射与页表 1. 内存映射 我们通常所说的内存容量,指的是物理内存,只有内核才可以直接访问物理内存,进程并不可以。 Linux 内核给每个进程都提供了一个独立的虚拟地址空间,并且这个地址空间是连续的。这样,…

如何用Python 快速搭建HTTP服务器

Python具有语法简单、语句清晰的特点,而且Python的兼容性比较好,可以将其他语言制作的模块联结起来,具有强大且丰富的库,封装后可以轻松调用,因此成为编程语言中的“网红“,甚至被称为非计算机从业者的第一语言。 Python在IT就业市场也是最受欢迎、最热门的技术技能…

SpringBoot整合Redis

SpringBoot整合Redis 文章目录SpringBoot整合Redis一 .简介1. redie是什么?2. redie的使用场景?二 . 使用1. 引入依赖2. 配置文件3. 启动redis4. 创建Redis工具类5. 创建测试类6. 查看效果一 .简介 1. redie是什么? Redis是现在最受欢迎的N…

图解计算机的存储器金字塔

本文已收录到 GitHub AndroidFamily,有 Android 进阶知识体系,欢迎 Star。技术和职场问题,请关注公众号 [彭旭锐] 进 Android 面试交流群。 前言 大家好,我是小彭。 在计算机组成原理中的众多概念中,开发者接触得最…

LeetCode-剑指43-1-n整数中出现1的次数

1、逐位统计 我们统计每一位k上面可能出现1的次数:1、对于每一位k上面的出现的1,我们首先统计其出现(n/10k)10k−1(n/10^k)\times10^{k-1}(n/10k)10k−1次的1;2、考虑到存在余数的情况,我们还需要比较剩余余数中出现1的次数&…

浅谈HTTP缓存与CDN缓存的那点事

HTTP缓存与CDN缓存一直是提升web性能的两大利器,合理的缓存配置可以降低带宽成本、减轻服务器压力、提升用户的体验。而不合理的缓存配置会导致资源界面无法及时更新,从而引发一系列的衍生问题。本文将分别将从HTTP缓存与cdn缓存的规则、流程、配置入手&…

XSS挑战之旅1-10关

文章目录前言第1关第2关第3关第4关第5关第6关第7关第8关第9关第10关前言 漏洞介绍:XSS漏洞 参考文章:XSS挑战之旅 游戏规则:触发alert()弹窗,进入下一关 第1关 进入第一关 随便输入一下,观测输出,看源代…

还在为数据库事务一致性检测而苦恼?让Elle帮帮你,以TDSQL为例我们测测 | DB·洞见#7

数据库用户通常依赖隔离级别来确保数据一致性,但很多数据库却并未达到其所表明的级别。主要原因是:一方面,数据库开发者对各个级别的理解有细微差异;另一方面,实现层面没有达到理论上的要求。 用户在使用或开发者在交…

147. SAP UI5 SmartTable 控件的使用介绍

本文来自笔者 SAP 开发技术交流知识星球内一位朋友的提问: smartfilter bar 有个输入框Cost Element绑定了cds实现value help 请问其对应的suggestion功能是通过cds的注解实现的嘛? 要回答这个问题,我们必须首先掌握 SAP UI5 SmartTable 控件的使用方式,然后才能深入探究 …

【Tensorflow】使用Tensorflow自定义模型和训练

Tensorflow的核心与NumPy非常相似,但具有GPU支持;Tensorflow支持分布式计算(跨多个设备和服务器)。 像NumPy一样使用TensorFlow 运算符是在Python 3.5 中添加的,用于矩阵乘法,等效于 tf.matmul() 函数。…