如何优化ThinkPHP中空值查询速度及处理空值的索引技巧?
- 内容介绍
- 文章标签
- 相关推荐
本文共计652个文字,预计阅读时间需要3分钟。
直接说结论:
为什么 WHERE name IS NULL 会慢?
MySQL 对 IS NULL 的索引支持有限——只有当字段有「允许 NULL」且被单独建了索引(或作为联合索引最左前缀),才能走索引。如果 name 字段是 NOT NULL DEFAULT '',那 IS NULL 实际永远查不到,但 MySQL 还是得扫全表确认一遍。
- 检查字段定义:
SHOW COLUMNS FROM user LIKE 'email';看Null列是否为YES - 确认索引存在:
SHOW INDEX FROM user WHERE Column_name = 'email'; - 联合索引如
(status, email)可以加速WHERE status = 1 AND email IS NULL,但单独WHERE email IS NULL无法利用它
whereNull() 和 ['exp', 'is null'] 有啥区别?
没本质区别,都是生成 IS NULL 条件。
本文共计652个文字,预计阅读时间需要3分钟。
直接说结论:
为什么 WHERE name IS NULL 会慢?
MySQL 对 IS NULL 的索引支持有限——只有当字段有「允许 NULL」且被单独建了索引(或作为联合索引最左前缀),才能走索引。如果 name 字段是 NOT NULL DEFAULT '',那 IS NULL 实际永远查不到,但 MySQL 还是得扫全表确认一遍。
- 检查字段定义:
SHOW COLUMNS FROM user LIKE 'email';看Null列是否为YES - 确认索引存在:
SHOW INDEX FROM user WHERE Column_name = 'email'; - 联合索引如
(status, email)可以加速WHERE status = 1 AND email IS NULL,但单独WHERE email IS NULL无法利用它
whereNull() 和 ['exp', 'is null'] 有啥区别?
没本质区别,都是生成 IS NULL 条件。

