不删除表中的数据 将id重置

allen0228 2009-05-08 06:51:31
对数据库中的表操作之后 id会自动增加1 这个效果是需要的
但是把数据全删除时 id 不是从1开始 是继续递增
通过执行truncate table table_name 可以使表的id重置为从1开始 可是表中的数据也没有了
问:
如何不删除数据 将数据库中的id重置
...全文
551 10 打赏 收藏 转发到动态 举报
写回复
用AI写文章
10 条回复
切换为时间正序
请发表友善的回复…
发表回复
allen0228 2009-05-14
  • 打赏
  • 举报
回复
难道没有其他能实现的方法 难道我太一想天开了
xinrui9949 2009-05-12
  • 打赏
  • 举报
回复
新手,来学习一下!!
jiahehao 2009-05-12
  • 打赏
  • 举报
回复
[Quote=引用 7 楼 ACMAIN_CHM 的回复:]
但是把数据全删除时 id 不是从1开始 是继续递增
通过执行truncate table table_name 可以使表的id重置为从1开始 可是表中的数据也没有了


那你的需求到底是什么?要不要保留表中的数据?如果不保留数据,则直接用你的方法 truncate table table_name 就行了。如果保留数据则不行,因为 AUTO_INCREMENT 必须是主键。
[/Quote]

楼主这个想法只有二楼的大搬运能实现。否则与mysql规则相抵触。
ACMAIN_CHM 2009-05-11
  • 打赏
  • 举报
回复

但是把数据全删除时 id 不是从1开始 是继续递增
通过执行truncate table table_name 可以使表的id重置为从1开始 可是表中的数据也没有了


那你的需求到底是什么?要不要保留表中的数据?如果不保留数据,则直接用你的方法 truncate table table_name 就行了。如果保留数据则不行,因为 AUTO_INCREMENT 必须是主键。
yuanwen1314 2009-05-11
  • 打赏
  • 举报
回复
up
WWWWA 2009-05-11
  • 打赏
  • 举报
回复
假设ID为自增
alter table dd drop id;
alter table dd add `id` int aUTO_INCREMENT, ADD INDEX (id);
ALTER TABLE dd AUTO_INCREMENT = 1;
select * from dd
allen0228 2009-05-11
  • 打赏
  • 举报
回复
楼上的加1 减1就错了
而且你的回答有点不符合我的要求 有没有别的办法
ACMAIN_CHM 2009-05-08
  • 打赏
  • 举报
回复

加上order by 就可以避免主键的冲突了。

mysql> create table table1(
-> id int AUTO_INCREMENT primary key,
-> col1 int
-> );
Query OK, 0 rows affected (0.16 sec)

mysql>
mysql> insert into table1(col1) values
-> (1),(2),(3),(4),(5);
Query OK, 5 rows affected (0.08 sec)
Records: 5 Duplicates: 0 Warnings: 0

mysql>
mysql> select * from table1;
+----+------+
| id | col1 |
+----+------+
| 1 | 1 |
| 2 | 2 |
| 3 | 3 |
| 4 | 4 |
| 5 | 5 |
+----+------+
5 rows in set (0.00 sec)

mysql>
mysql> update table1 set id=id+1;
ERROR 1062 (23000): Duplicate entry '2' for key 'PRIMARY'

mysql> update table1 set id=id+1 order by id desc;
Query OK, 5 rows affected (0.06 sec)
Rows matched: 5 Changed: 5 Warnings: 0

mysql> select * from table1;
+----+------+
| id | col1 |
+----+------+
| 2 | 1 |
| 3 | 2 |
| 4 | 3 |
| 5 | 4 |
| 6 | 5 |
+----+------+
5 rows in set (0.00 sec)

mysql>


allen0228 2009-05-08
  • 打赏
  • 举报
回复
问题是解决了 可是这种方法 我早想到了
想知道有没有更好的办法
liangCK 2009-05-08
  • 打赏
  • 举报
回复
-- 先将数据放到一个临时表中
CREATE TEMPORARY TABLE tmp_name
AS
SELECT xx,xxx,xxxx FROM table_name;

TRUNCATE TABLE table_name;

INSERT tmp_name(xx,xxx,xxx)
SELECT xx,xxx,xxxx FROM tmp_name;

DROP TABLE tmp_name;
PowerBI系列之Power Query专题1.  获取数据 数据源种类介绍和获取Excel数据源输入数据和拷贝数据:创建辅助表解析Json/XML数据格式获取Web网页数据和URL添加动态参数连接数据的四种模式:Import、DirectQuery、Live Connection、Dual双 属于混合模式连接数据库:Sql server、 Mysql(直连但是必须先安装一个mysql插件)DirectQuery直连查询:Sql serverODBC方式获取数据表关联或多个Sql或调用存储过程获取数据SQL动态传参和自定义函数: sql使用参数或数据库名称使用参数连接Sharepoint和OneDrive数据源连接Dataset和Dataflow 替换本地数据源为Sharepoint数据源并保留数据处理操作 终止当前数据刷新Loading:Cancel Query数据源设置-重置数据连接凭证PBIDS连接数据源创建和使用报表模块(输入或值列表)利用报表模板和参数控制线下报表数据权限DirectQuery启用自动页面刷新和更改检测管理聚合表提高DirectQuery查询性能动态M查询参数提高DirectQuery查询性能添加数据刷新时间 DateTime.LocalNow()和Getdate()2.  数据清洗和M语言M语言和官方文档介绍PowerQuery查阅M函数:=#shared, Ctrl+Space提示数据清洗之常用技能:提升标题、更改数据类型、保留删除错误或空行,删除重复项、选择列和删除列、填充单元格、合并列、拆分、提取、替换、条件替换、添加自定义列,添加条件列、添加索引列、分组、添加年月日列、追加和合并查询透视和逆透视以及转置合并单元格的Excel文件处理导入文件夹多Excel文件并合并解决多文件合并列顺序不一致使用参数和函数批量导入文件 文本提取文、英文、数字等处理双引号转义 列拆分详解解决列名改变错误解决列丢失错误动态显示、排序和重命名列为所有列名添加前缀列名字母大写和分隔符调整Trim标题列的多余空格如何处理load数据错误为什么load的Excel数据有null空行为什么load的Excel数据标题在第二行灵活添加占位符规范同类相似数据数据按多列排序为分组添加Index序号分组内值合并诊断工具分析数据处理过程PowerQuery小技巧分享 新冠病例活动轨迹地图标识 

56,677

社区成员

发帖
与我相关
我的任务
社区描述
MySQL相关内容讨论专区
社区管理员
  • MySQL
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧