ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

如何处理MySQL中自动增量ID列的碎片

2019-06-10 23:17:09  阅读:183  来源: 互联网

标签:mysql auto-increment


我有一个带有auto_increment字段的表,有时会删除行,因此auto_increment会留下空白.有没有办法避免这种情况,或者如果没有,至少,如何编写一个SQL查询:

>将auto_increment值更改为max(当前值)1
>返回新的auto_increment值?

我知道如何编写第1部分和第2部分,但是我可以将它们放在同一个查询中吗?

如果那是不可能的:

如何“选择”(返回)auto_increment值或auto_increment值1?

解决方法:

重新编号会引起混淆.现有报告将引用记录99,但如果系统重新编号,它可能会将该记录重新编号为98,现在所有报告(和填充的UI)都是错误的.一旦你分配了一个唯一的ID,就必须保持固定.

将ID字段用于除简单唯一编号之外的任何其他内容都会有问题.要求“无间隙”只是与能够删除的要求不一致.也许您可以将记录标记为已删除而不是删除它们.然后真的没有差距.假设您正在生成编号的发票:您将使用该编号取消零值取消发票而不是删除它.

标签:mysql,auto-increment
来源: https://codeday.me/bug/20190610/1214209.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有