SQL Server:Identity列采用随机范围

 跟-着感觉走 发布于 2023-02-13 01:46

在处理SQL Server数据库时,我发现SQL Server 2012 Enterprise Edition中的标识列值突然跳转到101.

数据库中共有10条记录(1到10).没有执行删除操作,并且在插入记录号11时,工具101.

我在浏览了一些在线帮助后找到了原因:

在这里,这里和这里.

这件事后面还有其他原因吗?

1 个回答
  • 可以设计.身份不保证是连续的,也不是单调的.没有人可以提供帮助,因为没有任何需要帮助.应用程序绝不应该依赖于没有间隙的身份.具有标识值行1,2,100,1000总是正常的.

    这怎么可能?好吧,首先,考虑一下这个简单的案例DELETE.显然删除行会留下空白.

    一个更微妙的问题是,即使没有删除,身份中的差距也会出现.这是因为有删除,你只是没有意识到它们.它们是由未提交的事务回滚引起的.回滚是无法阻止的,因为禁止回滚很难说"这将永远成功!",即.忽视现实(失败).在插入中间断开连接的客户端是回滚,您永远不能阻止它.

    总是期待差距.代码期待差距.永远不要依赖于连续的身份.

    我将不得不使用序列来解决这个问题

    序列具有完全相同的问题.这不是对设计的一些疏忽,这是一个基本问题:没有高效的方法来生成连续的,无间隙的ID.唯一的解决方案是序列化所有输入(例如表X锁定),没有人愿意这样做.

    2023-02-13 02:17 回答
撰写答案
今天,你开发时遇到什么问题呢?
立即提问
热门标签
PHP1.CN | 中国最专业的PHP中文社区 | PNG素材下载 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有