您好,登錄后才能下訂單哦!
小編給大家分享一下mysql中采用uuid而不使用自增ID有什么優勢,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
采用uuid而不使用自增ID的,
優勢:
1、數據遷移時不會有主鍵沖突。
2、在使用分布式架構的主主同步時,也無需配置auto_increment_offset/auto_increment_increment,保證搭建比較簡單。
劣勢:
1、uuid比bigint占用存儲空間大。
2、數據量達到500w以上性能明顯沒有bigint快。
(性能從哪些方面去比較呢?)
單條查詢,
范圍查詢,
范圍統計,
插入,
更新,
備份恢復。
#######################################################
#這里我們只做了一個單條查詢的效率比較
#######################################################
環境:單個臺式機
ubuntu 14.04 64位,
cpu cores=2
mem=7935M
測試步驟:
1、分別創建以id,uuid為主鍵的表。
2、分別插入100w條記錄(編寫存儲過程生成測試數據,收獲:需要關閉自動提交,效率大大的提升)。
3、分別以id ,uuid執行單條查詢。
4、比較查詢時間
最后結果都是在0秒以內完成。
腳本見附件。
#################################
DELIMITER $$
USE `test`$$
DROP PROCEDURE IF EXISTS `p_product_uuid`$$
CREATE DEFINER=`root`@`%` PROCEDURE `p_product_uuid`(IN n BIGINT)
BEGIN
DECLARE i INT DEFAULT 1 ;
SET autocommit = 0;
WHILE
(i <= n) DO
INSERT INTO tmp_id_uuid (id, UUID)
VALUES
(i, UUID()) ;
SET i = i + 1 ;
END WHILE ;
COMMIT;
SET autocommit = 1;
END$$
DELIMITER ;
#####################################
ps:在調試過程中,遇到sql一直在執行,需要停止掉,處理方式如下:
show processlist;
找出你要停止的語句
然后找出你要終止的語句的id
在系統下mysqladmin -uroot -ppassword kill 要殺的ID
#####################################
mysql> truncate table tmp_id_uuid;
Query OK, 0 rows affected (0.14 sec)
mysql> select count(*) from tmp_id_uuid;
+----------+
| count(*) |
+----------+
| 0 |
+----------+
1 row in set (0.00 sec)
mysql> call p_product_uuid(100000);
Query OK, 0 rows affected (5.16 sec)
mysql> select count(*) from tmp_id_uuid;
+----------+
| count(*) |
+----------+
| 100000 |
+----------+
1 row in set (0.04 sec)
mysql> truncate table tmp_id_uuid;
Query OK, 0 rows affected (0.15 sec)
mysql> call p_product_uuid(1000000);
Query OK, 0 rows affected (43.03 sec)
mysql> create table tmp2_id_uuid as select * from tmp_id_uuid;
Query OK, 1000000 rows affected (18.07 sec)
Records: 1000000 Duplicates: 0 Warnings: 0
mysql> select count(*) from tmp2_id_uuid;
+----------+
| count(*) |
+----------+
| 1000000 |
+----------+
1 row in set (0.31 sec)
mysql> alter table tmp_id_uuid add primary key (id);
Query OK, 0 rows affected (24.14 sec)
Records: 0 Duplicates: 0 Warnings: 0
mysql> alter table tmp2_id_uuid add primary key (uuid);
Query OK, 0 rows affected (25.94 sec)
Records: 0 Duplicates: 0 Warnings: 0
mysql>
mysql>
mysql> flush tables;
Query OK, 0 rows affected (0.00 sec)
mysql> select * from tmp_id_uuid where id=500000;
+--------+--------------------------------------+
| id | uuid |
+--------+--------------------------------------+
| 500000 | e3332083-c743-11e6-bc1e-00e066731e45 |
+--------+--------------------------------------+
1 row in set (0.00 sec)
mysql> flush tables;
Query OK, 0 rows affected (0.00 sec)
mysql> select * from tmp2_id_uuid where uuid='e3332083-c743-11e6-bc1e-00e066731e45';
+--------+--------------------------------------+
| id | uuid |
+--------+--------------------------------------+
| 500000 | e3332083-c743-11e6-bc1e-00e066731e45 |
+--------+--------------------------------------+
1 row in set (0.00 sec)
mysql>
mysql>
以上是“mysql中采用uuid而不使用自增ID有什么優勢”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。