在线精品99_中国九九盗摄偷拍偷看_91免费版在线观看_91.app_91高清视频在线_99热最新网站

如何解决mysql中auto

136次阅读
没有评论

共计 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字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)
主站蜘蛛池模板: 好好的曰com久久 | 国产热re99久久6国产精品 | 免费国产成人高清在线观看不卡 | 免费观看国产短视频的方法 | 国产原创麻豆 | 中文字幕亚洲无线码在线一区 | 日本视频免费看 | 丁香五月综合久久激情 | 亚洲女久久久噜噜噜熟女 | 黄动漫免费看 | 欧美日韩中文国产 | 99久久精品免费看国产四区 | 国产视频不卡在线 | 国产精品自在自线亚洲 | 韩国毛片 | 国产精品久久久久9999吃药 | 久热这里只有精品6 | 不卡一区 | 香港午夜三级a三级 | 少妇人妻偷人精品视蜜桃 | 久久99精品久久久久久动态图 | 成年美女黄网站色大片免费软件看 | 午夜影院免费 | 欧美毛片大全 | 精品一区二区三区四区乱码90 | 亚洲乱码中文字幕在线 | 国产精品久久久久久52avav | 天堂免费在线视频 | 中文字幕乱码人妻综合二区三区 | 欧美精品一区在线看 | vr成人片在线播放网站 | 麻豆国产成人av高清在线 | 亚洲三级成人 | 思思久久q6热在精品国产 | 亚洲成a人不卡在线观看 | 老司机免费在线观看视频 | 国产精品v免费视频 | 亚洲精品一区二区国产精华液 | 欧美精品一区二区三区视频 | 一级毛片片 | 亚洲av第一页国产精品 |