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

首頁 > 數據庫 > MySQL > 正文

Mysql怎樣存儲唯一識別碼UUID

2024-07-24 12:35:12
字體:
來源:轉載
供稿:網友
  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查詢,因為邏輯上相鄰的行會分布在磁盤和內存中的各個地方。隨機值導致緩存對所有類型的查詢性能都很差,因為它們會使緩存賴以工作的訪問局部性失效。如果整個數據集都變得同樣“熱”的時候,那么把特定部分的數據緩存到內存中就沒有任何的優勢了,并且如果工作集不能被裝入內存中,緩存就會進行很多刷寫的工作,并且會導致很多緩存未命中.
 
  如果保存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,’-',”);   

      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。
 

(編輯:武林網)

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 集贤县| 电白县| 沾益县| 玛曲县| 武清区| 常州市| 噶尔县| 邻水| 高邑县| 吉安县| 云龙县| 昆明市| 阿克陶县| 吉隆县| 曲水县| 榆林市| 德阳市| 古浪县| 陆丰市| 禹州市| 芜湖市| 梁平县| 垫江县| 泰宁县| 西城区| 鄂伦春自治旗| 阿拉善右旗| 西吉县| 五常市| 益阳市| 克东县| 潍坊市| 凌海市| 青浦区| 银川市| 镇安县| 武平县| 苗栗市| 平邑县| 桑日县| 北海市|