我试图将参数添加到我准备好的语句中,查询和数组看起来正确。但是会触发“类型定义字符串中的元素数量与绑定(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/