ALTER TABLE MODIFY 会静默截断超长数据,且不报错;需先检查长度、开事务验证;utf8mb4下VARCHAR字符数≠字节数,索引易超限;TEXT不可直接转VARCHAR;隐式转换多因collation不一致导致索引失效。ALTER TABLE MODIFY 会截断超长数据直接改字段长度时,MySQL 不会自动帮你校验现有数据是否超出新长度------超了就硬截断,且默认不报错。比如把 VARCHAR(255) 改成 VARCHAR(50),所有原长度 >50 的值末尾会被无声砍掉。必须先用 SELECT 查一遍: SELECT id, column_name FROM table_name WHERE LENGTH(column_name) > 50;生产环境务必加 SET SQL_SAFE_UPDATES = 0; 前先开事务:BEGIN;,试改后立刻 ROLLBACK; 验证效果如果字段有索引,MODIFY 可能触发表重建(尤其 InnoDB),大表会锁表数分钟utf8mb4 下的字符数 ≠ 字节数很多人以为设成 VARCHAR(100) 就能存 100 个汉字,但用 utf8mb4 字符集时,一个 emoji 或生僻字占 4 字节,而 VARCHAR 的长度参数是「字符数」不是「字节数」------看起来没问题,实际建表可能失败。错误现象:ERROR 1071 (42000): Specified key was too long...,尤其出现在加索引时原因:InnoDB 单索引长度上限是 767 字节(老版本)或 3072 字节(5.7+ with innodb_large_prefix=ON),VARCHAR(255) 在 utf8mb4 下最多占 1020 字节,远超 767解法不是缩字段,而是确认 innodb_large_prefix 和 ROW_FORMAT=DYNAMIC 是否启用;否则得把索引列显式限制长度,如 INDEX(col_name(191))TEXT 类型不能直接用 MODIFY 缩容想把 TEXT 改成 VARCHAR(500)?MySQL 不让。类型变更受严格限制,TEXT → VARCHAR 属于"不安全转换",会报错 ERROR 1170 (42000): BLOB/TEXT column 'xxx' used in key specification without a key length。 通义听悟 阿里云通义听悟是聚焦音视频内容的工作学习AI助手,依托大模型,帮助用户记录、整理和分析音视频内容,体验用大模型做音视频笔记、整理会议记录。
相关推荐
无心水1 小时前
【Hermes:MCP 与工具实战】29、数据库 MCP 实战:MySQL/PostgreSQL/SQLite 自然语言查询Dshuishui1 小时前
我用 Claude Code 做了一个学术论文搜索工具ㄟ留恋さ寂寞1 小时前
怎样修改提示“表已空”的空状态界面_Empty State插画替换研究点啥好呢1 小时前
Momenta后端开发面试题精选:10道高频考题+答案解析(数据产线方向)老歌老听老掉牙1 小时前
空间点到平面的距离:几何意义与计算方法m0_591364731 小时前
SQL提升开发效率_使用CTE重构嵌套子查询逻辑Elnaij1 小时前
MySQL数据库入门到进阶!!(1)——在云服务器中安装MySQL(centos)2401_831419442 小时前
JavaScript 中实现基于分组的前端产品筛选功能曲幽2 小时前
初探:用 FastAPI 搭建你的第一个 AI Agent 接口