PHP-PDO : bindParam token syntax issue

标签 php mysql pdo

这个错误有解决办法吗?这是因为查询中的 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/

相关文章:

php - 正在更新 MySQL 时间戳记录,但受影响的行仍然为 0

php - 在 PDO 中每次准备后是否需要绑定(bind)参数?

php - 使用 AWS DynamoDB 和 PHP 进行分页

php - 如何知道 $string 是否以 ',' 结尾?

php - 使用 AJAX 更改面板标题文本

尝试创建检查数据的函数时出现 MySQL 错误代码?

mysql - SQL 更新语句不适用于 281 条记录

php - HTML 表单 -> Mysql

php - 在现有项目中加载 Zend Framework 组件

php - 如何在此类中上传多张图片