日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

MySQL自增长主键探究

發布時間:2025/7/14 数据库 24 豆豆
生活随笔 收集整理的這篇文章主要介紹了 MySQL自增长主键探究 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

MySQL自己主動增長使用的keyword是 AUTO_INCREMENT; 由于屬于 DDL。所以不區分大寫和小寫. 使用的列,必須被定義為 key, 比方主鍵,唯一鍵等。

本文中使用的數據庫是 MariaDB 5.5.5

默認事務隔離界別是 REPEATABLE-READ

client是安裝 Windows版本號 MariaDB時附帶安裝的 HeidiSQL .

社區免費版的下載頁面為: https://downloads.mariadb.org/mariadb/

創建測試表

使用client連接到server, 用戶為 root,password也是 root 如:

mysql -h localhost -P 3306 -u root -proot

先選擇切換 database:

USE `test`;

創建測試表:

DROP TABLE IF EXISTS `test_auto`;CREATE TABLE `test_auto` (`id` INT NOT NULL AUTO_INCREMENT,PRIMARY KEY (`id`) ) COMMENT='測試自己主動增長' COLLATE='utf8_general_ci' ENGINE=InnoDB;

client1的操作

使用新的client1連接到server, 用戶為 root,password也是 root 如:

mysql -h localhost -P 3306 -u root -proot

切換 database:

USE `test`;

然后,在client1之中, 開啟事務, 插入一些數據, 可是不提交.

# 在client1中運行 begin ; insert into test_auto() values(); insert into test_auto() values(); insert into test_auto() values(); insert into test_auto() values(); insert into test_auto() values(); insert into test_auto() values();

此時,能夠使用查詢語句

SELECT * FROM `test`.`test_auto`;

能夠看到, 得到了6條數據, id 是 1-6, 相應著我們插入數據的SQL數。由于我們沒有提交, 所以這個結果僅僅能在client1中看見。

client2的操作

使用新的client2連接到server, 用戶為 root,password也是 root 如:

mysql -h localhost -P 3306 -u root -proot

切換 database:

USE `test`;

然后,在client2之中, 開啟事務, 插入一些數據, 也不提交.

# 在client2中運行 begin ; insert into test_auto() values(); insert into test_auto() values(); insert into test_auto() values(); insert into test_auto() values(); insert into test_auto() values();

此時,能夠使用查詢語句

SELECT * FROM `test`.`test_auto`;

能夠看到, 得到了5條數據, id 是 7-11, 相應著我們插入數據的SQL數。由于我們沒有提交, 所以這個結果僅僅能在client2中看見。

這里我們能夠看到,自增的主鍵是全局唯一的,假設有事務回滾,那么已經自增的部分,是不會受影響的。

多個事務之間的自增主鍵也不會互相影響, 能保證唯一,但不能保證終于的記錄是連續的。

注意

通過client1和client2的操作,能夠發現沒提交的事務操作其它client是不能看到的。

這是 REPEATABLE-READ 事務隔離級別, 在開啟事務后, 還沒提交前, client看到的記錄, 是 事務開啟那一刻的快照, 加上本次會話中運行操作的結果。保證在事務運行過程中,不受其它會話所提交事務的影響。

假設事務的隔離級別是 READ COMMITtED , 僅僅能看到提交成功的記錄。

查詢事務隔離級別: select @@tx_isolation

client3的操作

使用新的client3連接到server, 用戶為 root,password也是 root 如:

mysql -h localhost -P 3306 -u root -proot

切換 database:

USE `test`;

然后,在client3之中, 先使用查詢語句:

SELECT * FROM `test`.`test_auto`;

能夠看到, 一條數據也沒有,由于還沒有數據被提交。

client1的操作-續

回到client1的窗體, 運行查詢語句:

SELECT * FROM `test`.`test_auto`;

能夠看到還是原先的6條記錄。

接著提交事務

commit;

client2的操作-續

回到client2的窗體, 運行查詢語句:

SELECT * FROM `test`.`test_auto`;

能夠看到還是原先的5條記錄。接著回滾事務

rollback;

再運行查詢語句:

SELECT * FROM `test`.`test_auto`;

能夠看到6條記錄(ID為1-6),為什么是6條? 由于回滾時本次事務就結束,然后也不讀取快照版本號,而是讀取全部可見的數據,即client1提交的數據。

其它操作

接著在client1中看到的也是6條記錄.

也能夠繼續運行幾次插入或者事務操作,中途查詢數據,并分析結果。

小結

MySQL的自己主動增長列, 保證了不反復,不保證中間不跳號(當然,不跳號僅僅有某些特殊業務有需求)。特別是在事務運行環境里運行時, 為了不影響邏輯與性能,也僅僅能採用這樣的處理方式。

GitHub版本號: https://github.com/cncounter/translation/blob/master/tiemao_2015/16_MySQL_AUTO_INCREMENT/MySQL_AUTO_INCREMENT.md

作者: 鐵錨 http://blog.csdn.net/renfufei

日期: 2015年06月01日

轉載于:https://www.cnblogs.com/gcczhongduan/p/5312842.html

總結

以上是生活随笔為你收集整理的MySQL自增长主键探究的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。