mysql中id(自动递增)如何清零?

mysql中id(自动递增)如何清零?,第1张

方法一: 如果曾经的数据都不需要的话,可以直接清空所有数据,并将自增字段恢复从1开始计数

truncate table

表名

方法二: dbcc checkident ('table_name', reseed,

new_reseed_value) 当前值设置为 new_reseed_value。如果自创建表后没有将行插入该表,则在执行 DBCC CHECKIDENT

后插入的第一行将使用 new_reseed_value 作为标识。否则,下一个插入的行将使用 new_reseed_value + 1。如果

new_reseed_value 的值小于标识列中的最大值,以后引用该表时将产生 2627 号错误信息。

方法二不会清空已有数据, *** 作比较灵活,不仅可以将自增值归零,也适用于删除大量连续行后,重新设置自增值并插入新的数据;或从新的值开始,当然不能和已有的冲突。

$sql="delete from $table_vote"

mysql_query($sql, $link)

$sql="alter table $table_vote auto_increment=1"

mysql_query($sql,

$link)

不能清零的,除非新建个表,但是这样一来原排序将混乱,如果非要新建表的话试试这两种 *** 作:

1、再弄个编号自己手动编最好,那个自动的就让他做为主键,作为系统 *** 作记录好了

2、在数据表中增设一个字段(例如ID),数据类型设为自动编号,将原自动编号字段删除,增设的字段序号即从新开始.再把新增字段改成刚删除掉那个字段名.如涉及主键,需要把主键改设一下.再改回来.

也就是说不用管每条记录的id会不会变咯?

方法一:使用select ...into outfile 和 load data infile ...

1.导出除了字段id的所有字段

2.清空表

3.导入数据

例子:

#建立测试表 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: 5 Duplicates: 0 Warnings: 0

#删除id=4的数据

mysql>delete from lt1 where id=4

Query OK, 1 row affected (0.08 sec)

#查看测试表的数据,这时候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中,注意指定字段名(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: 4 Deleted: 0 Skipped: 0 Warnings: 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: 5 Duplicates: 0 Warnings: 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: 4 Duplicates: 0 Warnings: 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中

mysql>insert into lt1 (v1,v2) select v1,v2 from lt11

Query OK, 4 rows affected (0.06 sec)

Records: 4 Duplicates: 0 Warnings: 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)

唔,这么辛苦,给个最佳至少啊...


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/10055524.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-04
下一篇 2023-05-04

发表评论

登录后才能评论

评论列表(0条)

保存