欧美成人精品手机在线观看_69视频国产_动漫精品第一页_日韩中文字幕网 - 日本欧美一区二区

LOGO OA教程 ERP教程 模切知識交流 PMS教程 CRM教程 開發文檔 其他文檔  
 
網站管理員

【SQL】別亂用UUID了,自增長ID和UUID性能差距你測過嗎?

admin
2024年8月27日 10:22 本文熱度 902

準備表&數據

UC_USER,自增ID為主鍵,表結構類似如下:

CREATE TABLE `UC_USER` (  `ID` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主鍵',  `USER_NAME` varchar(100) DEFAULT NULL COMMENT '用戶名',  `USER_PWD` varchar(200) DEFAULT NULL COMMENT '密碼',  `BIRTHDAY` datetime DEFAULT NULL COMMENT '生日',  `NAME` varchar(200) DEFAULT NULL COMMENT '姓名',  `USER_ICON` varchar(500) DEFAULT NULL COMMENT '頭像圖片',  `SEX` char(1) DEFAULT NULL COMMENT '性別, 1:男,2:女,3:保密',  `NICKNAME` varchar(200) DEFAULT NULL COMMENT '昵稱',  `STAT` varchar(10) DEFAULT NULL COMMENT '用戶狀態,01:正常,02:凍結',  `USER_MALL` bigint(20) DEFAULT NULL COMMENT '當前所屬MALL',  `LAST_LOGIN_DATE` datetime DEFAULT NULL COMMENT '最后登錄時間',  `LAST_LOGIN_IP` varchar(100) DEFAULT NULL COMMENT '最后登錄IP',  `SRC_OPEN_USER_ID` bigint(20) DEFAULT NULL COMMENT '來源的聯合登錄',  `EMAIL` varchar(200) DEFAULT NULL COMMENT '郵箱',  `MOBILE` varchar(50) DEFAULT NULL COMMENT '手機',  `IS_DEL` char(1) DEFAULT '0' COMMENT '是否刪除',  `IS_EMAIL_CONFIRMED` char(1) DEFAULT '0' COMMENT '是否綁定郵箱',  `IS_PHONE_CONFIRMED` char(1) DEFAULT '0' COMMENT '是否綁定手機',  `CREATER` bigint(20) DEFAULT NULL COMMENT '創建人',  `CREATE_DATE` datetime DEFAULT CURRENT_TIMESTAMP COMMENT '注冊時間',  `UPDATE_DATE` datetime DEFAULT CURRENT_TIMESTAMP COMMENT '修改日期',  `PWD_INTENSITY` char(1) DEFAULT NULL COMMENT '密碼強度',  `MOBILE_TGC` char(64) DEFAULT NULL COMMENT '手機登錄標識',  `MAC` char(64) DEFAULT NULL COMMENT 'mac地址',  `SOURCE` char(1) DEFAULT '0' COMMENT '1:WEB,2:IOS,3:ANDROID,4:WIFI,5:管理系統, 0:未知',  `ACTIVATE` char(1) DEFAULT '1' COMMENT '激活,1:激活,0:未激活',  `ACTIVATE_TYPE` char(1) DEFAULT '0' COMMENT '激活類型,0:自動,1:手動',  PRIMARY KEY (`ID`),  UNIQUE KEY `USER_NAME` (`USER_NAME`),  KEY `MOBILE` (`MOBILE`),  KEY `IDX_MOBILE_TGC` (`MOBILE_TGC`,`ID`),  KEY `IDX_EMAIL` (`EMAIL`,`ID`),  KEY `IDX_CREATE_DATE` (`CREATE_DATE`,`ID`),  KEY `IDX_UPDATE_DATE` (`UPDATE_DATE`)) ENGINE=InnoDB AUTO_INCREMENT=7122681 DEFAULT CHARSET=utf8 COMMENT='用戶表'

UC_USER_PK_VARCHAR表,字符串ID為主鍵,采用uuid:

CREATE TABLE `UC_USER_PK_VARCHAR_1` (  `ID` varchar(36) CHARACTER SET utf8mb4 NOT NULL DEFAULT '0' COMMENT '主鍵',  `USER_NAME` varchar(100) DEFAULT NULL COMMENT '用戶名',  `USER_PWD` varchar(200) DEFAULT NULL COMMENT '密碼',  `BIRTHDAY` datetime DEFAULT NULL COMMENT '生日',  `NAME` varchar(200) DEFAULT NULL COMMENT '姓名',  `USER_ICON` varchar(500) DEFAULT NULL COMMENT '頭像圖片',  `SEX` char(1) DEFAULT NULL COMMENT '性別, 1:男,2:女,3:保密',  `NICKNAME` varchar(200) DEFAULT NULL COMMENT '昵稱',  `STAT` varchar(10) DEFAULT NULL COMMENT '用戶狀態,01:正常,02:凍結',  `USER_MALL` bigint(20) DEFAULT NULL COMMENT '當前所屬MALL',  `LAST_LOGIN_DATE` datetime DEFAULT NULL COMMENT '最后登錄時間',  `LAST_LOGIN_IP` varchar(100) DEFAULT NULL COMMENT '最后登錄IP',  `SRC_OPEN_USER_ID` bigint(20) DEFAULT NULL COMMENT '來源的聯合登錄',  `EMAIL` varchar(200) DEFAULT NULL COMMENT '郵箱',  `MOBILE` varchar(50) DEFAULT NULL COMMENT '手機',  `IS_DEL` char(1) DEFAULT '0' COMMENT '是否刪除',  `IS_EMAIL_CONFIRMED` char(1) DEFAULT '0' COMMENT '是否綁定郵箱',  `IS_PHONE_CONFIRMED` char(1) DEFAULT '0' COMMENT '是否綁定手機',  `CREATER` bigint(20) DEFAULT NULL COMMENT '創建人',  `CREATE_DATE` datetime DEFAULT CURRENT_TIMESTAMP COMMENT '注冊時間',  `UPDATE_DATE` datetime DEFAULT CURRENT_TIMESTAMP COMMENT '修改日期',  `PWD_INTENSITY` char(1) DEFAULT NULL COMMENT '密碼強度',  `MOBILE_TGC` char(64) DEFAULT NULL COMMENT '手機登錄標識',  `MAC` char(64) DEFAULT NULL COMMENT 'mac地址',  `SOURCE` char(1) DEFAULT '0' COMMENT '1:WEB,2:IOS,3:ANDROID,4:WIFI,5:管理系統, 0:未知',  `ACTIVATE` char(1) DEFAULT '1' COMMENT '激活,1:激活,0:未激活',  `ACTIVATE_TYPE` char(1) DEFAULT '0' COMMENT '激活類型,0:自動,1:手動',  PRIMARY KEY (`ID`),  UNIQUE KEY `USER_NAME` (`USER_NAME`),  KEY `MOBILE` (`MOBILE`),  KEY `IDX_MOBILE_TGC` (`MOBILE_TGC`,`ID`),  KEY `IDX_EMAIL` (`EMAIL`,`ID`),  KEY `IDX_CREATE_DATE` (`CREATE_DATE`,`ID`),  KEY `IDX_UPDATE_DATE` (`UPDATE_DATE`)) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='用戶表';


500w級數據測試

# 自增id為主鍵的表
mysql> select count(1) from UC_USER;
+----------+
| count(1) |
+----------+
|  5720112 |
+----------+
1 row in set (0.00 sec)


# uuid為主鍵的表
mysql> select count(1) from UC_USER_PK_VARCHAR_1;
+----------+
| count(1) |
+----------+
|  5720112 |
+----------+
1 row in set (1.91 sec)

1、錄入500W數據,自增ID節省一半磁盤空間

占據的空間容量來看,自增ID比UUID小一半左右。

2、單個數據走索引查詢,自增id和uuid相差不大

3、范圍like查詢,自增ID性能優于UUID

4、寫入測試,自增ID是UUID的4倍

5、備份和恢復,自增ID性能優于UUID


500W總結

在500W記錄表的測試下:
1、普通單條或者20條左右的記錄檢索,uuid為主鍵的相差不大幾乎效率相同;
2、 但是范圍查詢特別是上百成千條的記錄查詢,自增id的效率要大于uuid;
3、在范圍查詢做統計匯總的時候,自增id的效率要大于uuid;
4、在存儲上面,自增id所占的存儲空間是uuid的1/2;
5、在備份恢復上,自增ID主鍵稍微優于UUID。


1000W總結

在1000W記錄表的測試下:
1、普通單條或者20條左右的記錄檢索,自增主鍵效率是uuid主鍵的2到3倍;
2、但是范圍查詢特別是上百成千條的記錄查詢,自增id的效率要大于uuid;
3、在范圍查詢做統計匯總的時候,自增id主鍵的效率是uuid主鍵1.5到2倍;
4、在存儲上面,自增id所占的存儲空間是uuid的1/2;
5、在寫入上面,自增ID主鍵的效率是UUID主鍵的3到10倍,相差比較明顯,特別是update小范圍之內的數據上面。
6、在備份恢復上,自增ID主鍵稍微優于UUID。

自增ID主鍵+步長,適合中等規模的分布式場景

在每個集群節點組的master上面,設置(auto_increment_increment),讓目前每個集群的起始點錯開 1,步長選擇大于將來基本不可能達到的切分集群數,達到將 ID 相對分段的效果來滿足全局唯一的效果。
  • 優點:實現簡單,后期維護簡單,對應用透明;
  • 缺點:第一次設置相對較為復雜,因為要針對未來業務的發展而計算好足夠的步長。


UUID,適合小規模的分布式環境

對于InnoDB這種聚集主鍵類型的引擎來說,數據會按照主鍵進行排序,由于UUID的無序性,InnoDB會產生巨大的IO壓力,而且由于索引和數據存儲在一起,字符串做主鍵會造成存儲空間增大一倍。
在存儲和檢索的時候,innodb會對主鍵進行物理排序,這對auto_increment_int是個好消息,因為后一次插入的主鍵位置總是在最后。
但是對uuid來說,這卻是個壞消息,因為uuid是雜亂無章的,每次插入的主鍵位置是不確定的,可能在開頭,也可能在中間,在進行主鍵物理排序的時候,勢必會造成大量的 IO操作影響效率,在數據量不停增長的時候,特別是數據量上了千萬記錄的時候,讀寫性能下降的非常厲害。
  • 優點:搭建比較簡單,不需要為主鍵唯一性的處理。
  • 缺點:占用兩倍的存儲空間(在云上光存儲一塊就要多花2倍的錢),后期讀寫性能下降厲害。


作者丨唐宋緣明卿_cris
來源丨網址:https://blog.csdn.net/qq_30108237/article/details/106856051



該文章在 2024/8/27 10:22:07 編輯過
關鍵字查詢
相關文章
正在查詢...
點晴ERP是一款針對中小制造業的專業生產管理軟件系統,系統成熟度和易用性得到了國內大量中小企業的青睞。
點晴PMS碼頭管理系統主要針對港口碼頭集裝箱與散貨日常運作、調度、堆場、車隊、財務費用、相關報表等業務管理,結合碼頭的業務特點,圍繞調度、堆場作業而開發的。集技術的先進性、管理的有效性于一體,是物流碼頭及其他港口類企業的高效ERP管理信息系統。
點晴WMS倉儲管理系統提供了貨物產品管理,銷售管理,采購管理,倉儲管理,倉庫管理,保質期管理,貨位管理,庫位管理,生產管理,WMS管理系統,標簽打印,條形碼,二維碼管理,批號管理軟件。
點晴免費OA是一款軟件和通用服務都免費,不限功能、不限時間、不限用戶的免費OA協同辦公管理系統。
Copyright 2010-2025 ClickSun All Rights Reserved