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

首頁 > 數據庫 > MySQL > 正文

Mysql 如何存儲唯一識別碼UUID

2024-07-24 12:35:23
字體:
來源:轉載
供稿:網友
  UUID含義是通用唯一識別碼,這 是一個軟件建構的標準,本教程我們來講講在Mysql中如何存儲UUID,通常用UUID做唯一標識,需要在數據庫中進行存儲.
 
  UUID的格式
 
  [java]
  
      String string = UUID.randomUUID().toString();   
      System.out.println(“uuid:” + string);  
  
  uuid:05ba463f-1dab-471f-81c7-58e0b06f35f0
  數據庫中直接存儲UUID的壞處:
 
  完全‘隨機’的字符串,例如由MD5()、SHA1()、UUID()產生的,它們產生的每一個新值都會被任意地保存在很大的空間范圍內,這會減慢INSERT及一些SELECT查詢。
 
  1)它們會減慢INSERT查詢,因為插入的值會被隨機地放入索引中,這會導致分頁、隨機磁盤訪問及聚集存儲引擎上的聚集索引碎片.
 
  2)它們會減慢SELECT查詢,因為邏輯上相鄰的行會分布在磁盤和內存中的各個地方。
 
  3)隨機值導致緩存對所有類型的查詢性能都很差,因為它們會使緩存賴以工作的訪問局部性失效。如果整個數據集都變得同樣“熱”的時候,那么把特定部分的數據緩存到內存中就沒有任何的優勢了,并且如果工作集不能被裝入內存中,緩存就會進行很多刷寫的工作,并且會導致很多緩存未命中.
 
  如果保存UUID值,就應該移除其中的短橫線,更好的辦法是使用UHEX()把UUID值轉化為16字節的數字,并把它保存在BINARY(16)列中.
 
  [sql]
  
      DELIMITER $$   
      CREATE FUNCTION `GuidToBinary`(   
          $Data VARCHAR(36)   
      ) RETURNS binary(16)   
      BEGIN
      DECLARE $Result BINARY(16) DEFAULT NULL;   
          IF $Data IS NOT NULL THEN
      SET $Data = REPLACE($Data,’-',”);   
      SET $Result = CONCAT(UNHEX(SUBSTRING($Data,7,2)),UNHEX(SUBSTRING($Data,5,2)),UNHEX(SUBSTRING($Data,3,2)), UNHEX(SUBSTRING($Data,1,2)),   
                      UNHEX(SUBSTRING($Data,11,2)),UNHEX(SUBSTRING($Data,9,2)),UNHEX(SUBSTRING($Data,15,2)) , UNHEX(SUBSTRING($Data,13,2)),   
                      UNHEX(SUBSTRING($Data,17,16)));   
      END IF;   
      RETURN $Result;   
      END
      $$   
      CREATE FUNCTION `ToGuid`(   
          $Data BINARY(16)   
      ) RETURNS char(36) CHARSET utf8   
      BEGIN
      DECLARE $Result CHAR(36) DEFAULT NULL;   
          IF $Data IS NOT NULL THEN
      SET $Result = CONCAT(HEX(SUBSTRING($Data,4,1)),HEX(SUBSTRING($Data,3,1)),HEX(SUBSTRING($Data,2,1)), HEX(SUBSTRING($Data,1,1)) , ‘-’,    --phpfensi.com
                      HEX(SUBSTRING($Data,6,1)),HEX(SUBSTRING($Data,5,1)),’-',   
                      HEX(SUBSTRING($Data,8,1)) , HEX(SUBSTRING($Data,7,1)),’-',   
                      HEX(SUBSTRING($Data,9,2)),’-',HEX(SUBSTRING($Data,11,6)));   
      END IF;   
      RETURN $Result;   
      END
  
  [sql]
  
      CREATE FUNCTION `UUIDTOBIN`() RETURNS binary(16)    
      BEGIN
      DECLARE my_uuid char(36);    
      SET my_uuid = UUID();    
      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)));    
      END
      CREATE FUNCTION `BINTOUUID`(UUID BINARY(16)) RETURNS char(36)    
      BEGIN
      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)));    
      END。

(編輯:武林網)

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 云和县| 外汇| 淮北市| 忻州市| 赣州市| 涟水县| 河东区| 监利县| 丹巴县| 长治县| 阜新市| 通河县| 汉寿县| 孝昌县| 昌乐县| 锡林浩特市| 苏尼特右旗| 塔河县| 平泉县| 泊头市| 海安县| 鹿邑县| 洛宁县| 柞水县| 巴林左旗| 彭水| 松滋市| 瑞安市| 太谷县| 溧水县| 汾阳市| 会泽县| 梅州市| 四会市| 三河市| 缙云县| 营口市| 伊金霍洛旗| 鸡泽县| 永丰县| 永丰县|