【问题标题】:SQLSTATE[HY093]: Invalid parameter number: number of bound variables does not match number of tokens errorSQLSTATE[HY093]: Invalid parameter number: number of bound variables does not match number of tokens错误
【发布时间】:2016-06-02 01:22:07
【问题描述】:

我的 2 个页面出现此错误,我不明白为什么。我已经重写了代码并对其进行了三次检查,但我找不到问题所在。

第一个是:

 public function academics ($id,$problem_solving ,  $math_understanding,      $cs_understanding ,   $math_useful ,  $cs_useful, $math_ava,  $cs_ava,    $assigment_start,   $assigment_submit,  $travel_time,   $stress,$assigment_when,    $full_part,     $pair_programming,  $attending_class,   $attending_labs,$attending_tutorials,   $extra_reading, $p_progamming,  $q_cs,  $q_maths,   $procrastinating_assigments,    $procrastinating_studying){
    try{
        $stmt = $this->db->prepare("UPDATE student_data SET problem_solving=:problemS, math_understanding=:math_U, cs_understanding=: cs_u, math_useful =:m, cs_useful=:cs_u, math_ava=:ma, cs_ava=:ca, assigment_start=:ass_st, assigment_submit=:assigment_submit, travel_time =:travel_time, stress=: stress, assigment_when =:assigment_when, full_part =:full_part, pair_programming=: pair_programming,   attending_class=: attending_class, attending_labs=: attending_labs, attending_tutorials =:attending_tutorials, extra_reading =:extra_reading, p_progamming=: p_progamming,  q_cs=: q_cs,    q_maths=: q_maths, procrastinating_assigments=:procrastinating_assigments, procrastinating_studying=:procrastinating_studying WHERE user_id=:uid");
        $stmt->bindparam(":uid", $id);
        $stmt->bindparam(":problemS",$problem_solving );
        $stmt->bindparam(":math_U",$math_understanding);
        $stmt->bindparam(":cs_u",$cs_understanding );
        $stmt->bindparam(":m",$math_useful );
        $stmt->bindparam(":cs_u",$cs_useful);
        $stmt->bindparam(":ma",$math_ava);
        $stmt->bindparam(":ca",$cs_ava);
        $stmt->bindparam(":ass_st",$assigment_start);
        $stmt->bindparam(":assigment_submit",$assigment_submit);
        $stmt->bindparam(":travel_time",$travel_time);
        $stmt->bindparam(":stress",$stress);
        $stmt->bindparam(":assigment_when",$assigment_when);
        $stmt->bindparam(":full_part",$full_part    );
        $stmt->bindparam(":pair_programming",$pair_programming);
        $stmt->bindparam(":attending_class",$attending_class);
        $stmt->bindparam(":attending_labs",$attending_labs);
        $stmt->bindparam(":attending_tutorials",$attending_tutorials);
        $stmt->bindparam(":extra_reading",$extra_reading);
        $stmt->bindparam(":p_progamming",$p_progamming);
        $stmt->bindparam(":q_cs",$q_cs);
        $stmt->bindparam(":q_maths",$q_maths);
        $stmt->bindparam(":procrastinating_assigments",$procrastinating_assigments);
        $stmt->bindparam(":procrastinating_studying",$procrastinating_studying);
        $stmt->execute(); 
    } catch(PDOException $e)
    {
        echo $e->getMessage();
    }  
}

第二个是:

public function comps ($id,$long,$often_comp,$gaming,$research,$doc,$music,$vid,$fix,$social){
    try{
        $stmt = $this->db->prepare("UPDATE student_data SET long=:long, often_comp=:often , gaming=:gaming, research=:research, doc=:doc, music=:music, vid=:vid, fix=:fix, social=:social  WHERE user_id=:uid");
        $stmt->bindparam(":uid",$id);
        $stmt->bindparam(":long",$long);
        $stmt->bindparam(":often",$often_comp);
        $stmt->bindparam(":gaming",$gaming);
        $stmt->bindparam(":research",$research);
        $stmt->bindparam(":doc",$doc);
        $stmt->bindparam(":music",$music);
        $stmt->bindparam(":vid",$vid);
        $stmt->bindparam(":fix",$fix);
        $stmt->bindparam(":social",$social);
        $stmt->execute(); 
    } catch(PDOException $e)
    {
        echo $e->getMessage();
    }  
}

【问题讨论】:

  • 错字,可能是: cs_u?您还使用了该名称两次..
  • ^ 即 long 这是 MySQL 的保留字,可能因此被关闭。如果有人回答它,我会用那个可能的欺骗来关闭它。
  • @chris85 是的......如果这是一个错字。查看我的评论 ^
  • 然后还有: q_cs,另一个空格。和: stress - 编辑:@chris85 这会变得更好,不是吗?

标签: php mysql sql


【解决方案1】:

好的,这对于评论来说太长了(顺便说一句,没有双关语)。

看到如果那些是不是拼写错误(我希望他们不是),你有很多在冒号后面有空格的绑定。

您需要删除它们的空格并将 MySQL 保留字包装在记号LONG 中,或将其重命名为保留字以外的名称。

SET `long`=:long, ...

参考:


脚注:

TBH:我没有计算你所有的绑定,所以如果我错过了什么,你需要检查它们并确保它们都匹配。


编辑:

“我不知道 php 的空格数,以为它像 C/C++ 一样忽略了它们,现在可以使用了。再次感谢大家!!-bandos”

  • 这不是 C/C++,而是 PHP,并且空格在该语言中也很重要。

【讨论】:

  • 我明白了,谢谢。我曾想过长期是 php 中的一个关键字,但它不是,没想到它是数据库部分的一部分。这与空间一起固定。再次感谢您的帮助!
  • @bandos 不客气。虽然没有义务,但会通知所有人找到了解决方案,请考虑接受答案以结束问题。以下是meta.stackexchange.com/questions/5234/… 然后返回此处并对勾号/复选标记执行相同操作直到它变为绿色的方法。这会通知社区,找到了解决方案。否则,其他人可能会认为问题仍然悬而未决,可能想要发布(更多)答案。欢迎使用 Stack。
  • 空格在 c/c++ 中不计算在内,除非是硬编码字符串,否则它们在编译时会被忽略
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2017-03-25
  • 2013-03-19
  • 2018-04-22
  • 1970-01-01
相关资源
最近更新 更多