这个错误有解决办法吗?这是因为查询中的 mySQL 时间格式而发生的吗?
SQL Error Error:SQLSTATE[HY093]: Invalid parameter number: number of bound variables does not match number of tokens Array ( [:service_user_id] => 90 [:week_beginning] => 2012-08-06 [:week_ending] => 2012-08-12 ) Backtrace:C:\wamp\www\Sitetest_9.6.12\public_html\main\ajax\timetable_grid_load.php at line 45
This is the PHP using php-pdo-wrapper-class:
$bind = array(
":service_user_id" => $service_user_id,
":week_beginning" => $week_beginning,
":week_ending" => $week_ending,
);
$query = "SELECT
id AS sessID,
session_day as sessDay,
session_type_id,
provider_id,
description,
TIME_FORMAT(start_time, '%H:%i') as start_time,
TIME_FORMAT(finish_time, '%H:%i') as finish_time,
start_date,
finish_date,
(SELECT absence FROM attendance WHERE sessID = session_id AND absence_date = DATE_ADD(':week_beginning', INTERVAL sessDay-1 DAY)) AS attendance
FROM
sessions
WHERE
service_user_id = :service_user_id AND
start_date <= ':week_ending' AND
(finish_date >= ':week_beginning' OR
finish_date IS NULL OR
finish_date=0)
ORDER BY session_day ASC";
$result= $db->run($query,$bind);
return $result;
最佳答案
不要使用单引号来分隔准备好的语句中的参数。这是没有必要的(这就是首先准备声明的全部意义)。
...
WHERE
service_user_id = :service_user_id AND
start_date <= :week_ending AND
(finish_date >= :week_beginning OR
finish_date IS NULL OR
...
提示:start_date <= ':week_ending'
翻译为less than or equal to the literal string ":week_ending"
。
关于PHP-PDO : bindParam token syntax issue,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11817070/