MySQL自增长主键探究
MySQL自己主動增長使用的keyword是 AUTO_INCREMENT; 由于屬于 DDL。所以不區(qū)分大寫和小寫. 使用的列,必須被定義為 key, 比方主鍵,唯一鍵等。
本文中使用的數(shù)據(jù)庫是 MariaDB 5.5.5
默認(rèn)事務(wù)隔離界別是 REPEATABLE-READ
client是安裝 Windows版本號 MariaDB時附帶安裝的 HeidiSQL .
社區(qū)免費(fèi)版的下載頁面為: https://downloads.mariadb.org/mariadb/
創(chuàng)建測試表
使用client連接到server, 用戶為 root,password也是 root 如:
mysql -h localhost -P 3306 -u root -proot先選擇切換 database:
USE `test`;創(chuàng)建測試表:
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之中, 開啟事務(wù), 插入一些數(shù)據(jù), 可是不提交.
# 在client1中運(yùn)行 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條數(shù)據(jù), id 是 1-6, 相應(yīng)著我們插入數(shù)據(jù)的SQL數(shù)。由于我們沒有提交, 所以這個結(jié)果僅僅能在client1中看見。
client2的操作
使用新的client2連接到server, 用戶為 root,password也是 root 如:
mysql -h localhost -P 3306 -u root -proot切換 database:
USE `test`;然后,在client2之中, 開啟事務(wù), 插入一些數(shù)據(jù), 也不提交.
# 在client2中運(yùn)行 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條數(shù)據(jù), id 是 7-11, 相應(yīng)著我們插入數(shù)據(jù)的SQL數(shù)。由于我們沒有提交, 所以這個結(jié)果僅僅能在client2中看見。
這里我們能夠看到,自增的主鍵是全局唯一的,假設(shè)有事務(wù)回滾,那么已經(jīng)自增的部分,是不會受影響的。
多個事務(wù)之間的自增主鍵也不會互相影響, 能保證唯一,但不能保證終于的記錄是連續(xù)的。
注意
通過client1和client2的操作,能夠發(fā)現(xiàn)沒提交的事務(wù)操作其它c(diǎn)lient是不能看到的。
這是 REPEATABLE-READ 事務(wù)隔離級別, 在開啟事務(wù)后, 還沒提交前, client看到的記錄, 是 事務(wù)開啟那一刻的快照, 加上本次會話中運(yùn)行操作的結(jié)果。保證在事務(wù)運(yùn)行過程中,不受其它會話所提交事務(wù)的影響。
假設(shè)事務(wù)的隔離級別是 READ COMMITtED , 僅僅能看到提交成功的記錄。
查詢事務(wù)隔離級別: 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`;能夠看到, 一條數(shù)據(jù)也沒有,由于還沒有數(shù)據(jù)被提交。
client1的操作-續(xù)
回到client1的窗體, 運(yùn)行查詢語句:
SELECT * FROM `test`.`test_auto`;能夠看到還是原先的6條記錄。
接著提交事務(wù)
commit;client2的操作-續(xù)
回到client2的窗體, 運(yùn)行查詢語句:
SELECT * FROM `test`.`test_auto`;能夠看到還是原先的5條記錄。接著回滾事務(wù)
rollback;再運(yùn)行查詢語句:
SELECT * FROM `test`.`test_auto`;能夠看到6條記錄(ID為1-6),為什么是6條? 由于回滾時本次事務(wù)就結(jié)束,然后也不讀取快照版本號,而是讀取全部可見的數(shù)據(jù),即client1提交的數(shù)據(jù)。
其它操作
接著在client1中看到的也是6條記錄.
也能夠繼續(xù)運(yùn)行幾次插入或者事務(wù)操作,中途查詢數(shù)據(jù),并分析結(jié)果。
小結(jié)
MySQL的自己主動增長列, 保證了不反復(fù),不保證中間不跳號(當(dāng)然,不跳號僅僅有某些特殊業(yè)務(wù)有需求)。特別是在事務(wù)運(yùn)行環(huán)境里運(yùn)行時, 為了不影響邏輯與性能,也僅僅能採用這樣的處理方式。
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日
轉(zhuǎn)載于:https://www.cnblogs.com/gcczhongduan/p/5312842.html
總結(jié)
以上是生活随笔為你收集整理的MySQL自增长主键探究的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Android 使用Jsoup解析Htm
- 下一篇: 深入理解java虚拟机---读后笔记(垃