user_id = '123' 走不了索引是因为MySQL对INT类型列隐式转为字符串比较,导致全表扫描;PostgreSQL则直接报错。EXPLAIN中type为ALL/index、Extra仅含Using where即为典型表现,SHOW WARNINGS可见CAST痕迹。WHERE 条件里 user_id = '123' 为什么走不了索引字符串和数字混用时,MySQL 会把列隐式转成字符串再比对,user_id 是 INT 类型,但传了字符串 '123',引擎不得不对整列做类型转换,索引失效是必然结果。PostgreSQL 更严格,直接报错;而 MySQL 默默执行却慢得离谱。查 EXPLAIN 的 type 字段:如果是 ALL 或 index(非 ref/range),大概率有隐式转换看 Extra 列:出现 Using where; Using index 是健康的;若只有 Using where,说明索引没被用于定位,只是最后过滤用 SHOW WARNINGS 查优化器重写后的语句,常能看到类似 CAST(user_id AS CHAR) 这样的痕迹PreparedStatement 参数绑定不等于类型安全Java 用 setString(1, "123") 给 INT 字段赋值,JDBC 驱动默认仍会发字符串过去------MySQL 收到后照旧隐式转换。真正起作用的是驱动层的类型提示,不是应用层的 setXxx 方法名。MySQL Connector/J 8.0+ 可加连接参数:useServerPrepStmts=true&cachePrepStmts=true&rewriteBatchedStatements=true,并确保 serverPreparedStatementDiscardThreshold 合理更可靠的做法是显式调用 setInt(1, 123),哪怕变量来源是字符串,也先 Integer.parseInt()(注意空值和异常)MyBatis 中 <if test="userId != null">AND user_id = #{userId} 不够,得配合 jdbcType=INTEGER 或让参数对象字段类型为 IntegerJSON 字段里的数字查询最容易翻车JSON 类型字段(如 extra_info)存了 {"age": 25},写 JSON_EXTRACT(extra_info, '$.age') = '25',MySQL 会把提取出的数字转成字符串比较,索引(哪怕建了函数索引)也白搭。 稿定AI 拥有线稿上色优化、图片重绘、人物姿势检测、涂鸦完善等功能
相关推荐
用户8356290780513 分钟前
使用 Python 操作 Word 评论和回复流星白龙8 分钟前
【MySQL高阶】26.事务(1)cfm_291414 分钟前
JVM类加载深入理解Zella折耳根22 分钟前
复习篇-继承和接口诗词在线25 分钟前
求推荐飞花令程序员二叉28 分钟前
【JVM】OOM详解+JVM参数+FullGC排查+CPU飙高+死锁+内存泄漏+命令大全yijianace39 分钟前
Python线程与多线程完全总结(从入门到理解并发本质)三十..1 小时前
Redis 核心原理与高可用架构实践不知名的老吴1 小时前
线程的生命周期之线程同步这个DBA有点耶1 小时前
索引优化深潜(下):索引合并、ICP 与索引设计的实战法则