我最近发现你可以在PDO中绑定空值:
$stmt = $db->prepare('SELECT * FROM foo WHERE bar = :bar');
$stmt->execute(array(':bar'=>null));
$foo = $stmt->fetchAll(PDO::FETCH_OBJ);
Run Code Online (Sandbox Code Playgroud)
这将成功foo从数据库中获取所有bar列,其中列为null.
但是,我现在想做相反的事情.我想获取所有列在bar列不空.
我知道我可以简单地替换bar = :bar用bar IS NOT NULL.但是,我想避免这种情况,而是通过预处理语句来完成它,因为我有时必须动态地构建查询字符串并且必须手动执行它将需要很多额外的工作.
这可能吗?
你不能绑定"NOT NULL".您只能绑定值."IS NOT NULL"不是一个值,它是完全不同的查询语法.您只需动态构建查询,值绑定无法帮助您:
$query = 'SELECT ... WHERE ';
if (/* condition is NOT NULL */) {
$query .= 'foo IS NOT NULL';
$stmt = $db->prepare($query);
} else {
$query .= 'foo = :foo';
$stmt = $db->prepare($query);
$stmt->bindValue('foo', $foo);
}
$stmt->execute();
Run Code Online (Sandbox Code Playgroud)
恐怕您的假设是错误的。尽管您通常可以绑定NULL值WHERE bar = NULL,但无论原始SQL还是PDO ,语句都不会返回任何行。整个语句将被评估为NULL,并且不会与任何行匹配。
相反,您可以使用NULL安全等于运算符的值<=>来匹配NULL或具有某些值的字段。但是要具有不为null的值,您仍然必须具有另一个查询。