PHP中空值转整型结果为0,但null、空字符串、false、'0'、'abc'等均转为0,导致语义混淆;应使用filter_var($val, FILTER_VALIDATE_INT)校验数字,数据库NULL需显式判断而非直接转换。

PHP 中将空值或 null 转为整型,结果是 0,但这个“看似安全”的隐式转换极易引发逻辑错误——尤其在判断用户输入、数据库字段或 API 返回值时。
PHP 空字符串、null、false 强制转 int 都得 0
PHP 的类型转换规则里,(int) ''、(int) null、(int) false 全部返回 0。这不是 bug,是语言设计,但会让“是否提供值”和“值是否为 0”完全无法区分。
-
(int) ''→0 -
(int) null→0 -
(int) false→0 -
(int) '0'→0(字符串数字也转成 0) -
(int) 'abc'→0(非法字符串同样得 0)
用 is_numeric() + filter_var() 才算真正校验数字输入
仅靠强制转换无法判断原始值是否“本意就是数字”。必须先确认它是不是可接受的数字格式,再转整型。
-
is_numeric('123')→true;is_numeric('')→false;但is_numeric('0x1A')也返回true(十六进制),慎用 - 更稳妥的是
filter_var($val, FILTER_VALIDATE_INT):只认十进制整数,''、null、'12.5'、' 42 '(带空格)全返回false - 若需允许带符号或指定范围,加选项:
filter_var($val, FILTER_VALIDATE_INT, ['options' => ['min_range' => 1, 'max_range' => 100]])
数据库字段为 NULL 时,intval() 和 (int) 都会静默变 0
从 MySQL 查询出的 INT 字段若允许 NULL,PHP 获取后是 null,不是字符串 'null'。直接 intval($row['score']) 或 (int)$row['score'] 会抹掉 NULL 语义。
立即学习“PHP免费学习笔记(深入)”;
- 查出
$row['score'] === null,但(int)$row['score'] === 0—— 原本“未评分”被当成“得分为 0” - 修复方式:显式判断
isset($row['score']) && is_int($row['score']),或用array_key_exists('score', $row) && $row['score'] !== null - PDO 可设
PDO::ATTR_ORACLE_NULLS => PDO::NULL_TO_STRING(仅 Oracle),但通用解法仍是业务层主动判空
真正危险的不是转换结果,而是你没意识到 null、空字符串、false、字符串 '0' 在转整型时全部坍缩为同一个值 0——而你的 if 分支可能正依赖这个“0”做关键决策。











