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自增长主键探究的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Android 使用Jsoup解析Htm
- 下一篇: 深入理解java虚拟机---读后笔记(垃