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 拥有线稿上色优化、图片重绘、人物姿势检测、涂鸦完善等功能
相关推荐
倔强的石头_8 小时前
《Kingbase护城河》——猎捕慢查询:执行计划的微观解析与索引调优实战SelectDB9 小时前
Apache Doris Python UDF:让 SQL 直接调用 Python 生态,支撑 Agent 时代复杂业务逻辑荣码17 小时前
GraphRAG:普通RAG只能回答"点"的问题,我踩了4个坑才搞懂金銀銅鐵1 天前
[Python] 基于欧几里得算法,实现分数约分计算器Lyn_Li1 天前
Kaggle Top 5 | 198只股票、200条数据的金融预测——BattleFin高分方案从零复现小九九的爸爸1 天前
前端想要入门Agent开发,要具备哪些Python基础?阿耶同学1 天前
手把手教你用 LangGraph 搭建三层嵌套 Agent 架构jiayou642 天前
KingbaseES 表级与列级加密完全指南花酒锄作田2 天前
Pydantic校验配置文件hboot2 天前
AI工程师第四课 - 深度学习入门