gpt4 book ai didi

php - 动态准备语句(绑定(bind)参数错误)

转载 作者:行者123 更新时间:2023-11-29 13:01:15 26 4
gpt4 key购买 nike

我试图将参数添加到我准备好的语句中,查询和数组看起来正确。但是会触发“类型定义字符串中的元素数量与绑定(bind)变量的数量不匹配”错误。

$sql = 'SELECT * FROM `feed` ';
$types = array();
$params = array();

if( isset($_GET['p']) ) {
$page = $_GET['p'];
}
else {
$page = 0;
}

if( isset($_GET['q']) ) {
$sql .= 'WHERE `title` LIKE ? ';
$search = $_GET['q'];
array_push($types, 's');
array_push($params, $search);
}

$sql .= 'ORDER BY `time` DESC LIMIT ?, 6';

array_push($types, 'i');
array_push($params, $page);

$stmt = $mysqli->prepare($sql);
$params = array_merge($types, $params);

$refs = array();
foreach($params as $key => $value)
$refs[$key] = &$params[$key];

call_user_func_array(array($stmt, 'bind_param'), $refs);

(从服务器打印)

查询:SELECT * FROM feed WHERE title LIKE ? ORDER BY 时间 DESC LIMIT ?, 6

数组合并:

Array
(
[0] => s
[1] => i
[2] => word
[3] => 0
)

谢谢。

最佳答案

我的理解是,第一个参数“types”是参数类型的字符串,而不是数组。因此示例的参数列表应如下所示:

Array
(
[0] => si
[1] => word
[2] => 0
)

这是未经测试的代码:但 implode 应该从 '$types' 数组中执行我们想要的操作

$strTypes = implode('', $types);

我稍后会检查。

关于php - 动态准备语句(绑定(bind)参数错误),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23317078/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com