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)
唔,这么辛苦,给个最佳至少啊...
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)