色婷婷狠狠18禁久久YY,CHINESE性内射高清国产,国产女人18毛片水真多1,国产AV在线观看

MySQL分庫分表之后,id主鍵如何處理?

林子帆2年前20瀏覽0評論

我從分庫分表存在的問題和怎么做來回答一下這個問題。。

一,分庫分表的ID主鍵不能依賴于數據庫的自增,因為多庫中會重復!

通常使用外接的數據組件獲取全局唯一的ID:比如加強型UUID(根據Ip,時間戳等得到)和使用Redis(RedisAtomicLong)和zookeeper的API獲取,Twitter的雪花算法等等!

二,分庫分表之后的連接查詢比較困難!

問題沒法避免,通常拆分SQL,使用多次查詢,用查到的結果再分別查別的結果!

三,分布式事務的數據一致性很難保證!

可以使用TCC編程模型保證兩處的事務都能正確提交,但是這種方式對代碼的侵入比較重!也可以使用基于消息的數據一致性保證!

四,多數據的排序,分組,統計會比較困難!

1,用多線程,對多個節點分別查詢,然后匯總!

2,也可以提前冗余查詢表,將所有的經常查詢的重點數據提前統一到個庫表里!

分庫分表涉及到的知識點比較多,建議使用專門的分庫分表組件!本人有mycat使用經驗,如果您有相關問題,歡迎前來探討!