文章詳情頁
數據庫設計 - MySQL數據庫主鍵問題
瀏覽:117日期:2022-06-15 15:33:26
問題描述
前幾天在項目組里,總監建議把所有數據表的主鍵設為字符串類型(UUID),由應用程序維護數據表的主鍵,問下這個主要是出于什么方面的考慮呢???P.S. 我們用的MySQL數據庫,存儲引擎用的InnoDB,看了很多DBA的文章建議是說InnoDB類型的表最好是使用自增主鍵...
問題解答
回答1:UUID生成主鍵避免了主鍵重復,程序易維護,@wangcw解釋的蠻好,至于劣勢,經驗所限,暫且沒遇上
回答2:就我理解,使用UUID優勢,重復性低,方便自動生成,不用考慮主鍵重復插入失敗問題;不建議使用UUID原因:數據量達到一定值后索引維護很不方便,數據庫性能大打折扣,對分片條理性也有一定影響。
回答3:使用UUID的話,得通過應用去維護主鍵,這樣的話不是很繁瑣么...
相關文章:
1. docker - 各位電腦上有多少個容器啊?容器一多,自己都搞混了,咋辦呢?2. java - spring boot 如何打包成asp.net core 那種獨立應用?3. java - 在用戶不登錄的情況下,用戶如何添加保存到購物車?4. datetime - Python如何獲取當前時間5. javascript - nginx反向代理靜態資源403錯誤?6. docker網絡端口映射,沒有方便點的操作方法么?7. 安全性測試 - nodejs中如何防mySQL注入8. javascript - 關于apply()與call()的問題9. docker start -a dockername 老是卡住,什么情況?10. python - 調用api輸出頁面,會有標簽出現,請問如何清掉?
排行榜
