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

首頁 > 數據庫 > MySQL > 正文

Mysql中存儲UUID去除橫線的方法

2024-07-24 13:06:46
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了Mysql中存儲UUID去除橫線的方法,本文給出了3個Mysql函數實現去除去UUID中的橫線,需要的朋友可以參考下
 

參考:

http://stackoverflow.com/questions/412341/how-should-i-store-guid-in-mysql-tables

通常用UUID做唯一標識,需要在數據庫中進行存儲。

UUID的格式

復制代碼代碼如下:

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)列中。

 

復制代碼代碼如下:

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)) , ‘-',   
                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

 

 

復制代碼代碼如下:

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 通化市| 武鸣县| 乌兰察布市| 株洲市| 新安县| 菏泽市| 塔河县| 晋州市| 寿宁县| 静宁县| 湖口县| 鞍山市| 新巴尔虎左旗| 滕州市| 吉林市| 迭部县| 汉中市| 华蓥市| 灌阳县| 张家口市| 碌曲县| 云林县| 新沂市| 临朐县| 汕尾市| 阿拉善盟| 佛学| 花莲县| 墨竹工卡县| 灌南县| 阳泉市| 岗巴县| 江口县| 丰都县| 新丰县| 四子王旗| 永吉县| 扶余县| 伊通| 陇西县| 嘉兴市|