如何修改MySql自增列的值1、清空表,恢复到初始值:
2、修改为任意值:
上述语句中,table_name为表名,15为要修改的值 , 这样下次插入的数据的自增列的值就是15 。
若修改的值与现有数据冲突,会自动修改为当前最大值+1 。
如图所示,修改自增列id为11,虽然显示修改成功,但是id=11已经是现有值 , 再插入时会自动把自增列的值变为当前最大值(14)加1,也就是15
将mysql自增id字段清零,也就是说不用管每条记录的id会不会变咯?
方法一MySQL怎么清空自增:使用select ...into outfile 和 loaddata infile ...
1.导出除MySQL怎么清空自增了字段id的所有字段
2.清空表
3.导入数据
例子MySQL怎么清空自增:
#建立测试表 lt1
mysql create table lt1(id int(10) auto_increment,v1 int(10) default 0,v2 int(10
) default 0,primary key(id))engine=innodb,default charset=utf8;
Query OK, 0 rows affected (0.11 sec)
#插入测试数据
mysql insert into lt1(v1,v2) values(1,1),(2,2),(3,3),(4,4),(5,5);
Query OK, 5 rows affected (0.06 sec)
Records: 5Duplicates: 0Warnings: 0
#删除id=4的数据
mysql delete from lt1 where id=4;
Query OK, 1 row affected (0.08 sec)
#查看测试表的数据MySQL怎么清空自增,这时候id不连续 。
mysql select * from lt1;
+----+------+------+
| id | v1| v2|
+----+------+------+
|1 |1 |1 |
|2 |2 |2 |
|3 |3 |3 |
|5 |5 |5 |
+----+------+------+
4 rows in set (0.00 sec)
#将表中的v1,v2字段导出到lt1.xls中 。
mysql select v1,v2 from lt1 into outfile 'd:/localdmp/data/lt1.xls';
Query OK, 4 rows affected (0.03 sec)
#清空lt1
mysql truncate table lt1;
Query OK, 0 rows affected (0.08 sec)
#从lt1.xls文件中导入数据到lt1中MySQL怎么清空自增,注意指定字段名(v1,v2) 。
mysql load data infile 'd:/localdmp/data/lt1.xls' into table lt1(v1,v2);
Query OK, 4 rows affected (0.08 sec)
Records: 4Deleted: 0Skipped: 0Warnings: 0
#现在id连续了
mysql select * from lt1;
+----+------+------+
| id | v1| v2|
+----+------+------+
|1 |1 |1 |
|2 |2 |2 |
|3 |3 |3 |
|4 |5 |5 |
+----+------+------+
4 rows in set (0.00 sec)
方法二:
使用临时表create table ...select ... 和 insert ...select ...
例子:
#还是lt1表,先清空
mysql truncate table lt1;
Query OK, 0 rows affected (0.08 sec)
#插入测试数据,id 1-5
mysql insert into lt1(v1,v2) values(1,1),(2,2),(3,3),(4,4),(
Query OK, 5 rows affected (0.06 sec)
Records: 5Duplicates: 0Warnings: 0
mysql select * from lt1;
+----+------+------+
| id | v1| v2|
+----+------+------+
|1 |1 |1 |
|2 |2 |2 |
|3 |3 |3 |
|4 |4 |4 |
|5 |5 |5 |
+----+------+------+
5 rows in set (0.00 sec)
#把id=4删除
mysql delete from lt1 where id=4;
Query OK, 1 row affected (0.06 sec)
mysql select * from lt1;
+----+------+------+
| id | v1| v2|
+----+------+------+
|1 |1 |1 |
|2 |2 |2 |
|3 |3 |3 |
|5 |5 |5 |
+----+------+------+
4 rows in set (0.00 sec)
#创建临时表lt11
mysql create table lt11 select v1,v2 from lt1;
Query OK, 4 rows affected (0.11 sec)
Records: 4Duplicates: 0Warnings: 0
#临时表的数据
mysql select *from lt11;
+------+------+
| v1| v2|
+------+------+
|1 |1 |
|2 |2 |
|3 |3 |
|5 |5 |
+------+------+
4 rows in set (0.00 sec)
#清空lt1
mysql truncate table lt1;
Query OK, 0 rows affected (0.06 sec)
#将临时表lt11的数据插入lt1中
推荐阅读
- flutterio任务的简单介绍
- 世界区块链大会美国,2021世界区块链产业高峰论坛
- 宝妈直播好物推荐文案,宝妈直播聊什么话题
- java写文法代码 java写入文本文件
- b站录屏直播是什么意思,b站录屏直播是什么意思啊
- 类似泡泡糖网络游戏,类似于泡泡堂的单机游戏
- 毕业设计网站首页推荐书,有创意的毕业设计网站
- php怎么改数据库密码 php修改mysql数据库
- 同德显卡3060怎么样,同德显卡3060怎么样啊