mysql 行自动增量为23_如何处理MySQL中自动增量ID列的碎片

我有一个带有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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值