php中查数据库null必须用is null而非= null;判断php变量是否为数据库空值应区分is_null()、empty()等行为差异,推荐封装is_db_empty()函数专用于判别null或空字符串。

PHP中WHERE条件查数据库空值(NULL)的写法
直接用 = NULL 是查不到的,MySQL里 NULL 不参与常规比较运算。必须用 IS NULL 或 IS NOT NULL。
常见错误写法:SELECT * FROM user WHERE name = NULL —— 这条永远返回空结果集。
- 正确查字段为
NULL:SELECT * FROM user WHERE name IS NULL - 查非
NULL且非空字符串:SELECT * FROM user WHERE name IS NOT NULL AND name != '' - 如果字段允许空字符串和
NULL并存,且你想把两者都排除,两个条件缺一不可
PHP中判断变量是null、空字符串还是“假值”的区别
empty()、is_null()、== ''、=== ''、!$var 行为完全不同,不能混用。
-
is_null($var)只在变量严格等于NULL时返回true,比如$var = null或未定义变量isset($var)为false -
empty($var)会把''、0、'0'、false、null、[]都判为“空”,容易误伤数字0或字符串'0' - 判断是否为空字符串,用
$var === ''最安全;只排除NULL和'',推荐:!is_null($var) && $var !== ''
从数据库取值后判断空值的典型陷阱
MySQL 的 NULL 经 PDO 或 mysqli 返回到 PHP 后,通常变成 PHP 的 null,但某些配置或类型转换可能让 NULL 字段返回空字符串(尤其用了 CAST 或视图),不能默认等价。
立即学习“PHP免费学习笔记(深入)”;
- 查之前先确认字段实际存储内容:用 phpMyAdmin 或
SELECT name, ISNULL(name), LENGTH(name) FROM user LIMIT 1辅助验证 - PDO 默认把 SQL
NULL映射为 PHPnull,但若设置了PDO::ATTR_EMULATE_PREPARES => true且驱动较老,偶有异常 - 读取后别急着用
empty(),先var_dump($row['name'])看真实类型——这是最省时间的排查方式
统一处理数据库空值的实用函数建议
与其每次手写一堆判断,不如封装一个轻量工具函数,明确表达业务意图。
function is_db_empty($value) {
return $value === null || $value === '';
}这个函数不碰 0、false、[],只专注解决“数据库字段没值”这一场景。调用时:if (is_db_empty($row['phone'])) { ... }。
注意:不要把它命名为 is_empty(),避免和框架或全局函数冲突;也不要加对数字、布尔的兼容逻辑——那已经超出“数据库空值”的语义边界了。











