激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務器之家:專注于服務器技術及軟件下載分享
分類導航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|數據庫技術|

香港云服务器
服務器之家 - 數據庫 - Mysql - 解析mysql中的auto_increment的問題

解析mysql中的auto_increment的問題

2019-12-29 16:39MYSQL教程網 Mysql

本篇文章是對mysql中的auto_increment的問題進行了詳細的分析介紹,需要的朋友參考下

今兒在逛論壇時,發現一個看似很簡單的問題,卻引起了大家的廣泛關注:
這是一道很早的面試題:
一張表,里面有ID自增主鍵,當insert了17條記錄之后,刪除了第15,16,17條記錄,再把Mysql重啟,再insert一條記錄,這條記錄的ID是18還是15 。
答案:

如果表的類型是MyISAM,那么是18。 
因為MyISAM表會把自增主鍵的最大ID記錄到數據文件里,重啟MySQL自增主鍵的最大ID也不會丟失。 
如果表的類型是InnoDB,那么是15。 
InnoDB表只是把自增主鍵的最大ID記錄到內存中,所以重啟數據庫或者是對表進行OPTIMIZE操作,都會導致最大ID丟失。

自己也做了個實驗,結果證實了上面的說法。真是慚愧啊,看似簡單的問題自己也打錯了。

復制代碼代碼如下:


mysql> 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)

 

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 style="COLOR: #ff0000">12</SPAN> DEFAULT CHARSET=utf8 |
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, Oracle 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 style="COLOR: #ff0000">9</SPAN> DEFAULT CHARSET=utf8 |


2,另外還有一個就是獲取當前數據庫表的自增字段數。 

復制代碼代碼如下:

mysql> select last_insert_id();
+------------------+
| last_insert_id() |
+------------------+
|                0 |
+------------------+
1 row in set (0.00 sec)

延伸 · 閱讀

精彩推薦
566
主站蜘蛛池模板: 一道本不卡一区 | 久久精品性视频 | 欧美成人午夜影院 | 亚洲成人免费电影 | 亚洲小视频在线观看,com | 免费看污视频在线观看 | 日本视频在线免费观看 | 被狠狠操| 欧洲a级片 | 亚洲精品欧美二区三区中文字幕 | 色戒在线版| 日韩一级片一区二区三区 | 精品一区二区在线视频 | 欧美交在线 | 天天草夜夜爽 | 久久久久久久久久综合 | 久草视频福利在线观看 | 日韩精品免费一区二区三区 | 国产一区在线免费 | 一级成人黄色片 | 久久精品视频网址 | 日本欧美中文字幕 | 91久久线看在观草草青青 | 鲁丝片一区二区三区免费入口 | 成人在线视频免费播放 | 精品乱码久久久久 | 国产一区二精品区在线 | 色综合久久久久久久久久久 | 欧美精品18videos性欧美 | 免费视频 久久久 | 国产91久久久 | 国产91在线高潮白浆在线观看 | 久久综合给合久久狠狠狠97色69 | 亚州综合图片 | 欧美a级大胆视频 | 国产精品色综合 | 日本成人一区 | 久国久产久精永久网页 | 国产精品av久久久久久网址 | 国产精品久久久久久影院8一贰佰 | 高清av免费 |