亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Mysql分庫分表之后主鍵處理的幾種方法

 更新時間:2022年02月15日 10:18:56   作者:jerry_dyy  
Mysql分庫分表之后,主鍵如何處理?本文主要介紹了Mysql分庫分表之后主鍵處理的幾種方法,具有一定的參考價值,感興趣的可以了解一下

數(shù)據(jù)庫自增 ID

搞一個數(shù)據(jù)庫,什么也不干,就用于生成主鍵。

你的系統(tǒng)里每次得到一個 id,都需要往那個專門生成主鍵的數(shù)據(jù)庫中通過插入獲取一個自增的ID,拿到這個 id 之后再往對應(yīng)的分庫分表里去寫入。

優(yōu)點(diǎn):方便簡單。

缺點(diǎn)單庫生成自增 id,要是高并發(fā)的話,就會有瓶頸的;如果你硬是要改進(jìn)一下,那么就專門開一個服務(wù)出來,這個服務(wù)每次就拿到當(dāng)前 id 最大值,然后自己遞增幾個 id,一次性返回一批 id,然后再把當(dāng)前最大 id 值修改成遞增幾個 id 之后的一個值;但是無論如何都是基于單個數(shù)據(jù)庫。

適合的場景:系統(tǒng)并發(fā)不大,只是因為數(shù)據(jù)量大的原因而去做的分庫分表的話,可以采用這種方式。

設(shè)置數(shù)據(jù)庫 sequence 或者表自增字段步長

可以通過設(shè)置數(shù)據(jù)庫 sequence 或者表的自增字段步長來進(jìn)行水平伸縮。

比如說,現(xiàn)在有 8 個服務(wù)節(jié)點(diǎn),每個服務(wù)節(jié)點(diǎn)使用一個 sequence 功能來產(chǎn)生 ID,每個 sequence 的起始 ID 不同,并且依次遞增,步長都是8

適合的場景:在用戶防止產(chǎn)生的 ID 重復(fù)時,這種方案實現(xiàn)起來比較簡單,也能達(dá)到性能目標(biāo)。但是服務(wù)節(jié)點(diǎn)固定,步長也固定,將來如果還要增加服務(wù)節(jié)點(diǎn),就不好搞了。

UUID

優(yōu)點(diǎn):本地生成,不需要基于數(shù)據(jù)庫;

缺點(diǎn):UUID 太長了、占用空間大;作為主鍵性能太差:UUID 不具有有序性,會導(dǎo)致 B+ 樹索引在寫的時候有過多的隨機(jī)寫操作(連續(xù)的 ID 可以產(chǎn)生部分順序?qū)懀?,還有,由于在寫的時候不能產(chǎn)生有順序的 append 操作,而需要進(jìn)行 insert 操作,導(dǎo)致頻繁的進(jìn)行頁分裂,性能下降明顯。

適合的場景:如果你是要隨機(jī)生成個什么文件名、編號之類的,你可以用 UUID,但是作為InnoDB表的主鍵是不能用 UUID 的。

UUID.randomUUID().toString().replace(“-”, “”) -> sfsdf23423rr234sfdaf

系統(tǒng)當(dāng)前時間戳+XXX

適合的場景:一般如果用這個方案,是將當(dāng)前時間戳跟很多其他的業(yè)務(wù)字段拼接起來,作為一個 id,如果業(yè)務(wù)上你覺得可以接受,那么也是可以的。你可以將別的業(yè)務(wù)字段值跟當(dāng)前時間拼接起來,組成一個全局唯一的編號。

Snowflake 算法

snowflake 算法是 twitter 開源的分布式 id 生成算法,采用 Scala 語言實現(xiàn),是把一個 64 位的 long 型的 id,1 個 bit 是不用的,用其中的 41 bit 作為時間戳(毫秒數(shù)),用 10 bit 作為工作機(jī)器 id,12 bit 作為序列號。

  • 1 bit:不用,為啥呢?因為二進(jìn)制里第一個 bit 為如果是 1,那么都是負(fù)數(shù),但是我們生成的 id 都是正數(shù),所以第一個 bit 統(tǒng)一都是 0。
  • 41 bit:表示的是時間戳,單位是毫秒。41 bit 可以表示的數(shù)字多達(dá) 2^41 - 1,也就是可以標(biāo)識 2^41 - 1 個毫秒值,換算成年就是表示69年的時間。
  • 10 bit:記錄工作機(jī)器 id,代表的是這個服務(wù)最多可以部署在 2^10臺機(jī)器上哪,也就是1024臺機(jī)器。但是 10 bit 里 5 個 bit 代表機(jī)房 id,5 個 bit 代表機(jī)器 id。意思就是最多代表 2^5個機(jī)房(32個機(jī)房),每個機(jī)房里可以代表 2^5 個機(jī)器(32臺機(jī)器)。
  • 12 bit:這個是用來記錄同一個毫秒內(nèi)產(chǎn)生的不同 id,12 bit 可以代表的最大正整數(shù)是 2^12 - 1 = 4096,也就是說可以用這個 12 bit 代表的數(shù)字來區(qū)分同一個毫秒內(nèi)的 4096 個不同的 id。
0 | 0001100 10100010 10111110 10001001 01011100 00 | 10001 | 1 1001 | 0000 00000000

到此這篇關(guān)于Mysql分庫分表之后主鍵處理的幾種方法的文章就介紹到這了,更多相關(guān)Mysql分庫分表主鍵內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • MySQL事務(wù)的ACID特性以及并發(fā)問題方案

    MySQL事務(wù)的ACID特性以及并發(fā)問題方案

    這篇文章主要介紹了MySQL事務(wù)的ACID特性以及并發(fā)問題方案,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下
    2022-07-07
  • MySql分表、分庫、分片和分區(qū)知識深入詳解

    MySql分表、分庫、分片和分區(qū)知識深入詳解

    這篇文章主要介紹了MySql分表、分庫、分片和分區(qū)知識深入詳解,如果有并發(fā)場景和數(shù)據(jù)量較大的場景的可以看一下文章,對你會有或多或少的幫助
    2021-03-03
  • MySQL5.5.27安裝圖文教程

    MySQL5.5.27安裝圖文教程

    本文通過圖文并茂的形式給大家介紹了mysql 5.5.27的安裝教程,非常不錯,具有參考借鑒價值,需要的朋友參考下吧
    2017-09-09
  • Mysql?SQL審核平臺Yearning本地部署方案

    Mysql?SQL審核平臺Yearning本地部署方案

    Yearning簡單高效的MYSQL 審計平臺一款MYSQL SQL語句/查詢審計工具,為DBA與開發(fā)人員使用.本地部署,注重隱私,簡單高效的MYSQL審計平臺,下面介紹Linux 簡單部署Yearning 并結(jié)合cpolar 內(nèi)網(wǎng)穿透工具實現(xiàn)遠(yuǎn)程訪問,破除訪問限制,提高工作效率,感興趣的朋友一起看看吧
    2024-01-01
  • 查詢MySQL安裝路徑的兩種方法

    查詢MySQL安裝路徑的兩種方法

    這篇文章主要給大家介紹了關(guān)于查詢MySQL安裝路徑的兩種方法,在使用MySQL時有時需要知道MySQL的安裝路徑才能進(jìn)行相關(guān)操作,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下
    2023-07-07
  • MySQL實現(xiàn)模糊查詢的高效方法總結(jié)(附30條優(yōu)化建議)

    MySQL實現(xiàn)模糊查詢的高效方法總結(jié)(附30條優(yōu)化建議)

    數(shù)據(jù)庫SQL優(yōu)化是老生常談的問題,在面對模糊查詢的時候又有什么好的優(yōu)化建議呢?這篇文章主要給大家介紹了關(guān)于MySQL實現(xiàn)模糊查詢的高效方法,文中還附30條優(yōu)化建議,需要的朋友可以參考下
    2024-03-03
  • MySQL備份與恢復(fù)之熱備(3)

    MySQL備份與恢復(fù)之熱備(3)

    熱備使用mysqldump命令進(jìn)行備份,此工具是MySQL內(nèi)置的備份和恢復(fù)工具,功能強(qiáng)大,它可以對整個庫進(jìn)行備份,可以對多個庫進(jìn)行備份,可以對單張表或者某幾張表進(jìn)行備份,需要了解的朋友可以參考下
    2015-08-08
  • MySQL全文索引應(yīng)用簡明教程

    MySQL全文索引應(yīng)用簡明教程

    這篇文章主要介紹了MySQL全文索引應(yīng)用簡明教程,需要的朋友可以參考下
    2016-10-10
  • MYSQL數(shù)據(jù)庫連接池及常見參數(shù)調(diào)優(yōu)方式

    MYSQL數(shù)據(jù)庫連接池及常見參數(shù)調(diào)優(yōu)方式

    這篇文章主要介紹了MYSQL數(shù)據(jù)庫連接池及常見參數(shù)調(diào)優(yōu)方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • Mysql之如何實現(xiàn)全外連接

    Mysql之如何實現(xiàn)全外連接

    這篇文章主要介紹了Mysql之如何實現(xiàn)全外連接問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-03-03

最新評論