PHP - 将 PDO 与 IN 子句数组一起使用

标签 php mysql pdo prepared-statement in-clause

我正在使用 PDO 执行带有 IN 子句的语句,该子句使用数组作为其值:

$in_array = array(1, 2, 3);
$in_values = implode(',', $in_array);
$my_result = $wbdb->prepare("SELECT * FROM my_table WHERE my_value IN (".$in_values.")");
$my_result->execute();
$my_results = $my_result->fetchAll();

上面的代码工作得很好,但我的问题是为什么这不起作用:
 $in_array = array(1, 2, 3);
    $in_values = implode(',', $in_array);
    $my_result = $wbdb->prepare("SELECT * FROM my_table WHERE my_value IN (:in_values)");
    $my_result->execute(array(':in_values' => $in_values));
    $my_results = $my_result->fetchAll();

此代码将返回 my_value 等于 $in_array 中第一个项目 (1) 的项目,但不返回数组中的其余项目(2 和 3) )。

最佳答案

PDO 不擅长处理这些事情。您需要动态创建一个带有占位符的字符串并将其插入查询中,同时以通常的方式绑定(bind)数组值。使用位置占位符,它会是这样的:

$in  = str_repeat('?,', count($in_array) - 1) . '?';
$sql = "SELECT * FROM my_table WHERE my_value IN ($in)";
$stm = $db->prepare($sql);
$stm->execute($in_array);
$data = $stm->fetchAll();

如果查询中还有其他占位符,您可以使用以下方法(代码取 self 的 PDO tutorial ):

您可以使用array_merge()函数将所有变量连接到一个数组中,并按照它们在查询中出现的顺序以数组的形式添加其他变量:

$arr = [1,2,3];
$in  = str_repeat('?,', count($arr) - 1) . '?';
$sql = "SELECT * FROM table WHERE foo=? AND column IN ($in) AND bar=? AND baz=?";
$stm = $db->prepare($sql);
$params = array_merge([$foo], $arr, [$bar, $baz]);
$stm->execute($params);
$data = $stm->fetchAll();

如果您使用命名占位符,代码会稍微复杂一些,因为您必须创建命名占位符的序列,例如:id0,:id1,:id2。所以代码是:

// other parameters that are going into query
$params = ["foo" => "foo", "bar" => "bar"];

$ids = [1,2,3];
$in = "";
$i = 0; // we are using an external counter 
        // because the actual array keys could be dangerous
foreach ($ids as $item)
{
    $key = ":id".$i++;
    $in .= ($in ? "," : "") . $key; // :id0,:id1,:id2
    $in_params[$key] = $item; // collecting values into a key-value array
}

$sql = "SELECT * FROM table WHERE foo=:foo AND id IN ($in) AND bar=:bar";
$stm = $db->prepare($sql);
$stm->execute(array_merge($params,$in_params)); // just merge two arrays
$data = $stm->fetchAll();

幸运的是,对于命名占位符,我们不必遵循严格的顺序,因此我们可以按任何顺序合并数组。

关于PHP - 将 PDO 与 IN 子句数组一起使用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37691209/

相关文章:

php - 通过删除重复项来限制结果,但保留最高的重复项?

php - JOB_TOO_BIG Pheanstalk - 可以做什么?

php - 从两个表中提取的 MySQL 查询,显示在正确的字段中

mysql - 共享 RDS 数据库

php - 无效的日期时间格式 : 1292 Incorrect datetime value

php - 使用 MySQL 和 PHP PDO 发出基于 SELECT 语句的运行查询

php - 如何使用 php pdo 连接检查 mysql 中的值?

php - 如何使用 jquery 自动完成在 MySql 中加载大量记录

带有服务器时间 PHP 的 Javascript 时钟

php - 谷歌 API OAuth 2.0 CURL 返回 "Required parameter is missing: grant_type"