如何解决mysql中auto

67次阅读
没有评论

共计 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 的问题”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-07-15发表,共计2068字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)