将一张表的主键(ID)重置为从1开始自增排列
如果你有一张表,你的主键是ID,然后由于测来测去的原因,你的ID不是从1开始连续的自增了。
终于有一天,使用这张表的某个系统要导入正式数据了,强迫症这时候就表现的明显了,浑身不自在,
这时候你就需要将这个主键ID重置一波了,方法是在这张表中新增一个字段,将ID里面的数据复制过去,
然后删除ID字段,接着新建一个ID字段,再接着将id字段自增且设为主键,最后将这个新增的ID列挪到第一列,
将那个用于复制最初ID内容的新增字段删除,一切OK.
1、在要操作的表 tablename 中新增一个字段 old_id;
alter table tablename add old_id int(10) not null;
2、将 id 字段的数据复制给 old_id;
update tablename set old_id=id;
3、删除 id 字段;
alter table tablename drop id;
4、新增一个 id 字段;
alter table tablename add id int(10) not null;
5、将这个新增的 id 字段设置为自增主键;
alter table tablename modify column id int(10) not null auto_increment, add primary key (id);
6、删除 old_id 列;
alter table tablename drop column old_id;
7、将最新的 id 列挪到最前面;
alter table tablename modify id int(10) first;
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
2016-04-20 隐藏<input type="file"> 实现点击div或图片打开文件选择路径