日韩性视频-久久久蜜桃-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自增长主键探究的全部內容,希望文章能夠幫你解決所遇到的問題。

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

主站蜘蛛池模板: 色窝窝综合色窝窝久久 | av一卡| av在线资源网站 | 高清一区二区在线 | 日本黄网站色大片免费观看 | 国产无毛片 | av不卡在线 | 色屁屁一区二区三区 | 手机在线观看日韩av | 色婷婷激情网 | 欧美国产中文 | 噜噜狠狠狠狠综合久久 | 久久影院国产 | 亚av| 国产资源第一页 | 亚洲精品国产一区 | 日韩亚洲在线观看 | 亚洲美女视频网 | 日韩视频一区二区三区在线播放免费观看 | 国产高清在线免费观看 | 色花堂在线 | 亚洲成人www | 欧美13p| 波多野结衣爱爱 | 性做久久久久久久久 | 青苹果av | 末发成年娇小性xxxxx | 亚洲成a人片77777kkkk | 韩国一级淫片免费看 | av狠狠干| 亚洲成人网页 | 丁香六月天婷婷 | 成人免费做受小说 | 巨乳在线播放 | 黄色国产片 | 久操资源网| 久草视频网站 | 日本三级视频在线播放 | 泰坦尼克号3小时49分的观看方法 | 午夜激情av在线 | 五月婷婷中文字幕 | 日韩在线观看不卡 | av无码一区二区三区 | 在线性视频 | 黄网在线免费看 | 欧美一区二区三区在线视频 | 成人乱人乱一区二区三区一级视频 | 色婷婷av一区二区三 | 粉嫩av一区二区白浆 | 中文字幕一区二区精品 | 精品亚洲乱码一区二区 | 六月丁香激情 | 日韩精品在线视频 | 中文无码精品一区二区三区 | 久久久看| 亚洲国产精品成人综合久久久 | 日本三级黄色大片 | 国产情侣久久 | 波多野吉衣一区二区三区 | 中文字av | 99久久精品一区 | 美女网站污 | av手机观看| 国产在线观 | av在线免费播放网址 | 日本高清网色 | 日日噜噜噜噜久久久精品毛片 | 国产精品久久久久久久久久久久久 | 亚洲精品一区二区三区在线 | 337p粉嫩大胆色噜噜狠狠图片 | 人人人人干| 91色吧| 好吊色视频一区二区 | 911成人网 | 中文字幕在线观看视频一区 | 中文字幕一区二区视频 | 老熟妇仑乱一区二区视频 | 天堂久久一区 | 国产欧美日韩在线 | 91欧美大片 | 国产盗摄视频在线观看 | 色网站在线播放 | 久久666 | 狠狠干在线视频 | 久久黄色影视 | 久久精品国产99精品国产亚洲性色 | 精品一区二区三区国产 | 欧美日韩xxxx | 精品视频一区二区三区在线观看 | 免费视频网站在线观看入口 | 99久久婷婷国产综合精品草原 | 亚洲视频1 | 亚洲免费成人 | 91天天射| 日本一区二区欧美 | 精品人妻一区二区三区免费看 | 久久精品中文闷骚内射 | 天天干天天干天天 | 精品美女在线观看 |