微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

php – PDO准备语句 – NULL

我有一个正在运行的删除查询,但只是意识到当$user_id为null(在某些情况下会发生)时这不起作用.
$id = 1;
$user_id = null;
$delete = $sql->prepare("
    DELETE FROM
        `game_player`
    WHERE
        `id` = ?
    AND
        `user_id` = ?
");
if ($delete->execute(array(
    $id,$user_id,));

有什么工作除了在值为null时有不同的查询,因为显然唯一的方法是使用user_id IS NULL而不是user_id = NULL …

DELETE FROM
    `game_player`
WHERE
    `id` = ?
AND
    (`user_id` = ? OR ? IS NULL)

混合时或与运算符一起使用时要小心括号.

如果$user_id实际上不是PHP类型为null,而是说一个空字符串,则应该修改上面的内容

...
AND
    (`user_id` = ? OR ? = '')

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐