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

我正在使用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不适用于此类情况。您需要动态创建带有问号的字符串并将其插入查询中。

$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();

如果查询中还有其他占位符,则可以使用以下方法(代码取自我的PDO教程):

您可以使用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 = "";

foreach ($ids as $i => $item)

{

$key = ":id".$i;

$in .= "$key,";

$in_params[$key] = $item; // collecting values into key-value array

}

$in = rtrim($in,","); // :id0,:id1,:id2

$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子句数组一起使用 的全部内容, 来源链接: utcz.com/qa/406346.html

回到顶部