国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 數(shù)據(jù)庫(kù) > MySQL > 正文

Mysql 如何存儲(chǔ)唯一識(shí)別碼UUID

2024-07-24 12:39:44
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

UUID含義是通用唯一識(shí)別碼,這 是一個(gè)軟件建構(gòu)的標(biāo)準(zhǔn),本教程我們來(lái)講講在Mysql中如何存儲(chǔ)UUID,通常用UUID做唯一標(biāo)識(shí),需要在數(shù)據(jù)庫(kù)中進(jìn)行存儲(chǔ).

UUID的格式

  1. [java] 
  2.  
  3.     String string = UUID.randomUUID().toString();   
  4.     System.out.println(“uuid:” + string);  
  5.  
  6. uuid:05ba463f-1dab-471f-81c7-58e0b06f35f0 

數(shù)據(jù)庫(kù)中直接存儲(chǔ)UUID的壞處:

完全‘隨機(jī)’的字符串,例如由MD5()、SHA1()、UUID()產(chǎn)生的,它們產(chǎn)生的每一個(gè)新值都會(huì)被任意地保存在很大的空間范圍內(nèi),這會(huì)減慢INSERT及一些SELECT查詢。

1)它們會(huì)減慢INSERT查詢,因?yàn)椴迦氲闹禃?huì)被隨機(jī)地放入索引中,這會(huì)導(dǎo)致分頁(yè)、隨機(jī)磁盤訪問及聚集存儲(chǔ)引擎上的聚集索引碎片.

2)它們會(huì)減慢SELECT查詢,因?yàn)檫壿嬌舷噜彽男袝?huì)分布在磁盤和內(nèi)存中的各個(gè)地方。

3)隨機(jī)值導(dǎo)致緩存對(duì)所有類型的查詢性能都很差,因?yàn)樗鼈儠?huì)使緩存賴以工作的訪問局部性失效。如果整個(gè)數(shù)據(jù)集都變得同樣“熱”的時(shí)候,那么把特定部分的數(shù)據(jù)緩存到內(nèi)存中就沒有任何的優(yōu)勢(shì)了,并且如果工作集不能被裝入內(nèi)存中,緩存就會(huì)進(jìn)行很多刷寫的工作,并且會(huì)導(dǎo)致很多緩存未命中.

如果保存UUID值,就應(yīng)該移除其中的短橫線,更好的辦法是使用UHEX()把UUID值轉(zhuǎn)化為16字節(jié)的數(shù)字,并把它保存在BINARY(16)列中.

  1. [sql] 
  2.  
  3.     DELIMITER $$   
  4.     CREATE FUNCTION `GuidToBinary`(   
  5.         $Data VARCHAR(36)   
  6.     ) RETURNS binary(16)   
  7.     BEGIN 
  8.     DECLARE $Result BINARY(16) DEFAULT NULL;   
  9.         IF $Data IS NOT NULL THEN 
  10.     SET $Data = REPLACE($Data,’-',”);   
  11.     SET $Result = CONCAT(UNHEX(SUBSTRING($Data,7,2)),UNHEX(SUBSTRING($Data,5,2)),UNHEX(SUBSTRING($Data,3,2)), UNHEX(SUBSTRING($Data,1,2)),   
  12.                     UNHEX(SUBSTRING($Data,11,2)),UNHEX(SUBSTRING($Data,9,2)),UNHEX(SUBSTRING($Data,15,2)) , UNHEX(SUBSTRING($Data,13,2)),   
  13.                     UNHEX(SUBSTRING($Data,17,16)));   
  14.     END IF;   
  15.     RETURN $Result;   
  16.     END 
  17.     $$   
  18.     CREATE FUNCTION `ToGuid`(   
  19.         $Data BINARY(16)   
  20.     ) RETURNS char(36) CHARSET utf8   
  21.     BEGIN 
  22.     DECLARE $Result CHAR(36) DEFAULT NULL;   
  23.         IF $Data IS NOT NULL THEN 
  24.     SET $Result = CONCAT(HEX(SUBSTRING($Data,4,1)),HEX(SUBSTRING($Data,3,1)),HEX(SUBSTRING($Data,2,1)), HEX(SUBSTRING($Data,1,1)) , ‘-’,    --Vevb.com 
  25.                     HEX(SUBSTRING($Data,6,1)),HEX(SUBSTRING($Data,5,1)),’-',   
  26.                     HEX(SUBSTRING($Data,8,1)) , HEX(SUBSTRING($Data,7,1)),’-',   
  27.                     HEX(SUBSTRING($Data,9,2)),’-',HEX(SUBSTRING($Data,11,6)));   
  28.     END IF;   
  29.     RETURN $Result;   
  30.     END 
  31.  
  32. [sql] 
  33.  
  34.     CREATE FUNCTION `UUIDTOBIN`() RETURNS binary(16)    
  35.     BEGIN 
  36.     DECLARE my_uuid char(36);    
  37.     SET my_uuid = UUID();    
  38.     RETURN CONCAT(UNHEX(LEFT(my_uuid,8)),UNHEX(MID(my_uuid,10,4)),UNHEX(MID(my_uuid,15,4)),UNHEX(MID(my_uuid,20,4)),UNHEX(RIGHT(my_uuid,12)));    
  39.     END 
  40.     CREATE FUNCTION `BINTOUUID`(UUID BINARY(16)) RETURNS char(36)    
  41.     BEGIN 
  42.     RETURN CONCAT(HEX(LEFT(uuid,4)),’-', HEX(MID(uuid,5,2)),’-', HEX(MID(uuid,7,2)),’-',HEX(MID(uuid,9,2)),’-',HEX(RIGHT(uuid,6)));    
  43.     END

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 大石桥市| 锦屏县| 外汇| 称多县| 随州市| 鸡东县| 安塞县| 仁布县| 图木舒克市| 疏勒县| 吉林市| 枣强县| 顺平县| 安庆市| 澳门| 收藏| 长乐市| 德江县| 喀喇沁旗| 泸西县| 梅州市| 山丹县| 达尔| 宜兰县| 屯门区| 兴和县| 葫芦岛市| 大兴区| 青河县| 昭通市| 保康县| 涡阳县| 景东| 中卫市| 临江市| 新郑市| 若羌县| 岫岩| 安岳县| 夹江县| 南漳县|