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 拥有线稿上色优化、图片重绘、人物姿势检测、涂鸦完善等功能
相关推荐
l1t1 小时前
DeepSeek v4辅助编写调用Python包对用户数据做统计分析的页面qq_342295821 小时前
MySQL怎样在触发器中引用新旧数据行_NEW与OLD关键字详解m0_746752301 小时前
如何配置Data Guard主备库目录结构不同_DB_FILE_NAME_CONVERT参数转换规则weixin_424999361 小时前
CSS如何解决CSS冲突导致的BUG_使用CSS层叠层特性隔离样式2301_816660211 小时前
将地址转换为可点击的 Google Maps 链接(支持动态生成)步辞1 小时前
rowspan属性跨页表格怎么处理_打印断页兼容建议【方法】weixin_458580121 小时前
Python模型部署怎么做_FastAPI封装模型为RESTful接口tjc199010052 小时前
如何用 has 与 delete 管理 Map 中的特定键值映射rleS IONS2 小时前
Redis五种用途