共计 2068 个字符,预计需要花费 6 分钟才能阅读完成。
这篇文章将为大家详细讲解有关如何解决 mysql 中 auto_increment 的问题,丸趣 TV 小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
mysql 中的 auto_increment 的问题
今儿在逛时,发现一个看似很简单的问题,却引起了大家的广泛关注:
这是一道很早的面试题:
一张表, 里面有 ID 自增主键, 当 insert 了 17 条记录之后, 删除了第 15,16,17 条记录, 再把 Mysql 重启,
再 insert 一条记录, 这条记录的 ID 是 18 还是 15。 www.2cto.com
答案:
如果表的类型是 MyISAM,那么是 18。
因为 MyISAM 表会把自增主键的最大 ID 记录到数据文件里,重启 MySQL 自增主键的最大 ID 也不会丢失。
如果表的类型是 InnoDB,那么是 15。
InnoDB 表只是把自增主键的最大 ID 记录到内存中,所以重启或者是对表进行 OPTIMIZE 操作,
都会导致最大 ID 丢失。
自己也做了个实验,结果证实了上面的说法。真是惭愧啊,看似简单的问题自己也打错了。
[html]
select * from test1;
+—-+———–+
| id | name |
+—-+———–+
| 1 | 陈兵辉 |
| 2 | chen |
| 3 | chen |
| 4 | chen |
| 5 | chen |
| 6 | chen |
| 7 | chen |
| 8 | chen |
| 9 | chen |
| 10 | chen |
| 11 | chen |
+—-+———–+
11 rows in set (0.00 sec)
www.2cto.com
mysql delete from test1 where id in (10,11,9);
Query OK, 3 rows affected (0.03 sec)
mysql show create table test1;
CREATE TABLE `test1` (
`id` int(11) NOT NULL auto_increment,
`name` varchar(10) default NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT= span >mysql exit;
Bye
[root@fsailing1 ~]# service mysqld restart
停止 MySQL: [确定]
启动 MySQL: [确定]
[root@fsailing1 ~]# mysql -uroot -p
Enter password:
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 2
Server version: 5.0.95 Source distribution
Copyright (c) 2000, 2011, and/or its affiliates. All rights reserved.
Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.
Type help; or \h for help. Type \c to clear the current input statement.
mysql use test;
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A
Database changed
mysql show create table test1;
| CREATE TABLE `test1` (
`id` int(11) NOT NULL auto_increment,
`name` varchar(10) default NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT= span >
2,另外还有一个就是获取当前数据库表的自增字段数。
[html]
mysql select last_insert_id();
+——————+
| last_insert_id() |
+——————+
| 0 |
+——————+
1 row in set (0.00 sec)
关于“如何解决 mysql 中 auto_increment 的问题”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。