MySQL中如何使用HEX函数转换十六进制_MySQL进制转换函数
HEX() 将字符串按字节编码(如utf8mb4)转为大写十六进制字符串,非按字符;数字转十六进制不补零;NULL返回NULL;还原须用严格校验的UNHEX()。HEX() 函数怎么把字符串转成十六进制直接用 HEX() 就行,它默认把输入的字符串按字节逐个转成两位十六进制大写表示。比如中文、emoji、二进制 blob 都能转,但要注意底层是按字节编码处理的,不是按字符。常见错误现象:HEX('你好') 返回的是 UTF-8 编码字节序列(如 E4BDA0E5A5BD),不是 GBK 或 Unicode 码点;有人误以为是“字符的十六进制值”,结果比对失败。输入是字符串:按当前连接字符集(通常是 utf8mb4)编码后转字节输入是数字:HEX(255) → FF,等价于整数转十六进制字符串,不补零输入是 NULL:返回 NULL,不是空字符串想转回原内容?得用 UNHEX(),且必须保证原始字节完整(不能被截断或中间加空格)UNHEX() 还原时为什么总得到 NULL 或乱码UNHEX() 对输入极其严格:只接受长度为偶数的纯十六进制字符串(0-9、A-F、a-f),任何非法字符、奇数长度、空格都会让整个函数返回 NULL —— 不报错,也不警告,容易误判为“数据丢了”。使用场景:常用于还原从日志、API 或前端传来的 hex 字符串(比如加密后的 token、图片 blob 的 hex 表示)。检查长度:LENGTH(col_hex) % 2 != 0 → 必然失败过滤干扰字符:前端传来的 "0xABC" 或 "ab cd ef" 都要先用 REPLACE() 和正则(MySQL 8.0+)清洗兼容性注意:MySQL 5.7 不支持正则替换,得靠嵌套 REPLACE(REPLACE(...)) 去空格和前缀性能影响:UNHEX() 是逐字节解析,大数据量时别在 WHERE 条件里对字段反复调用,尽量提前解码存到新列HEX() 和 CONV() 在进制转换上的根本区别HEX() 是编码/序列化函数,CONV() 是纯数学进制转换函数,二者目的不同,不能混用。 文心快码 文心快码(Comate)是百度推出的一款AI辅助编程工具
