prepared statement where value is in array(值在数组中的预准备语句)
本文介绍了值在数组中的预准备语句的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
在php页面中,我有一个数组,如下所示:
$category = array(16, 22, 23);
然后,我使用预准备语句执行数据库查询。我要获取字段category
包含$category
数组中的一个值,并且price
小于变量$price
中存储的值的所有行。
其中,我阅读了this问题的答案,并尝试使用那里描述的find_in_set()
(以及在许多其他地方),但不知何故,我无法使其在准备好的语句中工作。我尝试过这个:
/* database connection "$db" is established beforehand and works */
if($ps = $db->prepare("
SELECT id, product, category, price
FROM products
WHERE price <= ? and find_in_set(?, category)
ORDER BY id") {
$ps->bind_param("ds", $price, $category);
$ps->execute();
$ps->bind_result($id, $name, $cat, $pr);
while($ps->fetch()) {
/* ... echo the results ..... */
}
$ps->free_result();
$ps->close();
}
但我得到的结果为空。
如果我尝试在bind_param()
行中使用"dd"或"di"而不是"ds",我确实会得到结果,但会得到错误的结果-我会得到类别为1的所有行。
我还尝试使用category IN ?
而不是find_in_set(?, category)
,但也不起作用。
我可以做些什么来实现这一点?感谢任何帮助!
推荐答案
两个问题:
该列表应作为第二个参数传递给
find_in_set
,因此应为:find_in_set(category, ?)
参数类型应为字符串(逗号分隔值)。因此,首先使用
implode
将您数组转换为这样的字符串:$csv = implode(",", $category);
编码:
if($ps = $db->prepare("
SELECT id, product, category, price
FROM products
WHERE price <= ? and find_in_set(category, ?)
ORDER BY id") {
$csv = implode(",", $category);
$ps->bind_param("ds", $price, $csv);
$ps->execute();
$ps->bind_result($id, $name, $cat, $pr);
while($ps->fetch()) {
/* ... echo the results ..... */
}
$ps->free_result();
$ps->close();
}
这篇关于值在数组中的预准备语句的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
沃梦达教程
本文标题为:值在数组中的预准备语句
基础教程推荐
猜你喜欢
- 在 Woocommerce 中根据运输方式和付款方式添加费用 2021-01-01
- mysqli_insert_id 是否有可能在高流量应用程序中返回 2021-01-01
- 通过 PHP SoapClient 请求发送原始 XML 2021-01-01
- 在 PHP 中强制下载文件 - 在 Joomla 框架内 2022-01-01
- 超薄框架REST服务两次获得输出 2022-01-01
- 在多维数组中查找最大值 2021-01-01
- WooCommerce 中选定产品类别的自定义产品价格后缀 2021-01-01
- Libpuzzle 索引数百万张图片? 2022-01-01
- 如何在 PHP 中的请求之间持久化对象 2022-01-01
- XAMPP 服务器不加载 CSS 文件 2022-01-01