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

相关推荐
Deitymoon2 小时前
嵌入式数据库——SQLite基础
数据库·sqlite
YMatrix 官方技术社区2 小时前
美国·硅谷|YMatrix 即将亮相 Postgres Conference 2026,前瞻 AI 时代的数据基座
数据库·数据仓库·postgresql·时序数据库·ymatrix
bKYP953cL2 小时前
构建自己的AI编程助手:基于RAG的上下文感知实现方案
数据库·人工智能·ai编程
Bert.Cai2 小时前
MySQL DML简介
数据库·mysql
maqr_1102 小时前
HTML怎么生成订单预览_HTML只读订单信息结构【操作】
jvm·数据库·python
sg_knight2 小时前
设计模式实战:责任链模式(Chain of Responsibility)
python·设计模式·责任链模式
2301_803875612 小时前
如何通过phpMyAdmin给WordPress所有用户发送全站通知_系统表插入
jvm·数据库·python
学弟3 小时前
【内涵】深度学习中的三种变量及pytorch中对应的三种tensor
人工智能·pytorch·python
2301_777599373 小时前
mysql如何进行数据库容量规划_评估磁盘空间增长趋势
jvm·数据库·python