mysql函数转义中文json(转换转义UTF-16(JSON实体)恢复正常UTF8 MySQL中)

本文介绍了如何在MySQL中使用Unjson函数进行JSON字符串解码,特别是处理UTF-8编码的情况,展示了函数的语法及其实现原理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

时间:2021-12-23 09:44:06

DELIMITER @@ 
CREATE FUNCTION Unjson (instring TEXT CHARACTER SET utf8) 
RETURNS TEXT CHARACTER SET utf8 
BEGIN 
 
    DECLARE i INT DEFAULT 0; 
    DECLARE c VARCHAR(1); 
    DECLARE utfstr TEXT CHARACTER SET utf16 DEFAULT ""; 
    DECLARE outstring TEXT CHARACTER SET utf8 DEFAULT ""; 
 
    WHILE i < CHAR_LENGTH(instring) DO 
    SET i = i + 1; 
    SET c = SUBSTRING(instring, i, 1); 
    IF c = "\\" THEN 
     SET c = SUBSTRING(instring, i + 1, 1); 
     IF c = "u" THEN 
     SET utfstr = CONCAT(utfstr, UNHEX(SUBSTRING(instring, i + 2, 4))); 
     SET i = i + 5; 
     END IF; 
    ELSE 
     IF utfstr != "" THEN 
     SET outstring = CONCAT(outstring, CONVERT(utfstr USING utf8)); 
     SET utfstr = ""; 
     END IF; 
     SET outstring = CONCAT(outstring, c); 
    END IF; 
    END WHILE; 
    IF utfstr != "" THEN 
    SET outstring = CONCAT(outstring, CONVERT(utfstr USING utf8)); 
    END IF; 
 
    RETURN outstring; 
END@@ 
DELIMITER ;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值