溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

mysql的主鍵有什么用

發(fā)布時(shí)間:2020-11-23 14:56:55 來(lái)源:億速云 閱讀:189 作者:小新 欄目:MySQL數(shù)據(jù)庫(kù)

這篇文章主要介紹了mysql的主鍵有什么用,具有一定借鑒價(jià)值,需要的朋友可以參考下。希望大家閱讀完這篇文章后大有收獲。下面讓小編帶著大家一起了解一下。

 (針對(duì)InnoDB引擎)我們實(shí)際生產(chǎn)環(huán)境可能會(huì)使用四類屬性作為主鍵:

(1). 自增序列;

(2). UUID()函數(shù)生成的隨機(jī)值;

(3). 用戶注冊(cè)的唯一性帳號(hào)名稱,字符串類型,一般長(zhǎng)度為:40個(gè)字符;

(4). 基于一套機(jī)制生成類似自增的值,比如序列生成器;

那么我們接下來(lái),再分析下這四類屬性各自作為表主鍵的優(yōu)缺點(diǎn):

(1)自增序列:從小到大 或從大到小的順序模式增加新值;數(shù)據(jù)類型也利于進(jìn)行主鍵值比較;存儲(chǔ)空間占用也相對(duì)最小,一般設(shè)置為:4個(gè)字節(jié)的INT類型或 8個(gè)字節(jié)的BIGINT類型;若是想進(jìn)行數(shù)據(jù)水平拆分的話,也可以借助設(shè)置mysqld實(shí)例的2個(gè)參數(shù):auto_increment_increment 和 auto_increment_offset;另外,唯一缺點(diǎn)就是自增序列是一個(gè)表級(jí)別的全局鎖,在5.0系列大規(guī)模并發(fā)寫的時(shí)候,因鎖釋放機(jī)制的問題容易出現(xiàn)瓶頸,但是5.1系列做了改進(jìn),基本上不存在此問題;

(2)UUID()函數(shù):值為隨機(jī)性+固定部分,其值產(chǎn)生是無(wú)序的,且同一臺(tái)服務(wù)器上產(chǎn)生的值相同部分為77.8%;產(chǎn)生的值字符個(gè)數(shù)為36,按utf8編碼計(jì)算,占用的存儲(chǔ)空間為36個(gè)字節(jié);對(duì)于數(shù)據(jù)水平拆分支持,無(wú)需特殊設(shè)置;

(3)使用用戶注冊(cè)的帳號(hào)名稱,字符串類型,其值的產(chǎn)生依賴用戶輸入,為此數(shù)據(jù)基本上為無(wú)序增加,字符串的長(zhǎng)度也是不定的,只能通過前段技術(shù)控制最短最大長(zhǎng)度值的限制,對(duì)水平拆分支持,無(wú)需做特殊設(shè)置;

(4)序列生成器的架構(gòu),類似自增序列,不過需要借助額外的開發(fā)工作量,以及提供一個(gè)第三方的服務(wù),可以規(guī)避自增序列的字增全局鎖的問題,提高并發(fā),對(duì)數(shù)據(jù)水平拆分可以更好地支持;

(5)雙主復(fù)制架構(gòu)的概率性碰到的場(chǎng)景:主服務(wù)器的數(shù)據(jù)執(zhí)行成功,而沒有復(fù)制到在線備用服務(wù)器時(shí),出問題的概率確實(shí)存在,其他類型的做法,也必須人工干涉解決,都無(wú)簡(jiǎn)單且合理的自動(dòng)化辦法,以上四種辦法都無(wú)法規(guī)避;

通過四種屬性值作為主鍵的優(yōu)缺點(diǎn)分析,以及對(duì)比前面我們闡述的主鍵需要的優(yōu)秀素質(zhì),若是不考慮水平拆分的問題,帶來(lái)額外設(shè)置上的麻煩,則自增序列是最佳的主鍵字段選擇;用戶的注冊(cè)帳號(hào)本身要求唯一性且非空的場(chǎng)景下,則可以作為主鍵字段的選擇;若是考慮水平拆分的問題,則采用自增序列生成器的架構(gòu),非常易用和可靠的實(shí)現(xiàn)方式,產(chǎn)生的值是最佳主鍵字段的選擇;

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享mysql的主鍵有什么用內(nèi)容對(duì)大家有幫助,同時(shí)也希望大家多多支持億速云,關(guān)注億速云行業(yè)資訊頻道,遇到問題就找億速云,詳細(xì)的解決方法等著你來(lái)學(xué)習(xí)!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI