栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

PHP

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

PHP

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

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



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/371091.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号