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 拥有线稿上色优化、图片重绘、人物姿势检测、涂鸦完善等功能
相关推荐
Teable任意门互动15 小时前
AI原生开源多维表格有哪些?主流开源多维表格对比解析Cloud_Shy61816 小时前
Python 数据分析基础入门:《Excel Python:飞速搞定数据分析与处理》学习笔记系列(第八章 使用读写包操作 Excel 文件 上篇)TDengine (老段)16 小时前
MNode 内部机制深度解析 — SDB、事务引擎与 DDL 处理全链路这个DBA有点耶16 小时前
数据库上云 vs 自建:从成本到人力的三维对比与决策框架shizhan_cloud16 小时前
MySQL 索引优化 + 慢查询日志輕華16 小时前
uv工具详解——Python包与项目管理器完全指南li星野16 小时前
位运算 & 数学 & 高频进阶九题通关(Python + C++)用户83562907805116 小时前
使用 Python 在 PowerPoint 中添加并控制音频播放Drache_long16 小时前
MySQL数据库(故障排除)2303_8212873816 小时前
如何清洗SQL输入数据_使用框架内置的ORM处理数据交互