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辅助编程工具

相关推荐
zhoutongsheng1 分钟前
MySQL触发器无法触发的原因分析_MySQL触发器排查指南
jvm·数据库·python
愈努力俞幸运2 分钟前
function calling与mcp
android·数据库·redis
夏沫琅琊2 分钟前
基于python 的日志文件分析器
python
财经资讯数据_灵砚智能3 分钟前
基于全球经济类多源新闻的NLP情感分析与数据可视化(夜间-次晨)2026年5月10日
大数据·人工智能·python·信息可视化·自然语言处理
2301_779622413 分钟前
不同品牌SSD对HTML函数工具加载速度影响大吗_存储测试汇总【汇总】
jvm·数据库·python
我滴老baby10 分钟前
0基础速通Python+AI|2026热门轻量化玩法全攻略:从入门到实战,3天搞定AI应用开发
开发语言·人工智能·python
雷帝木木13 分钟前
Python 类型提示与静态类型检查的高级应用
人工智能·python·深度学习·机器学习
一个天蝎座 白勺 程序猿13 分钟前
Python(29)Python生成器函数深度解析:asyncio事件循环的底层实现与异步编程实战
开发语言·python
七夜zippoe14 分钟前
Python RESTful API设计终极指南:从理论到企业级实战
开发语言·python·http·pandas·restful api
dinglu1030DL16 分钟前
golang如何实现告警分级与升级_golang告警分级与升级实现步骤
jvm·数据库·python