为了账号安全,请及时绑定邮箱和手机立即绑定

SQLSTATE[HY093]:参数数量无效:绑定变量的数量与标记数量不匹配 COUNT 是正确的

SQLSTATE[HY093]:参数数量无效:绑定变量的数量与标记数量不匹配 COUNT 是正确的

PHP
收到一只叮咚 2023-08-11 16:15:26
我一直对此感到困惑并尝试解决问题几个小时。我在 StackOverflow 上阅读了大约 30 个关于这个相同错误的问题。似乎没有一个相关。字段名称和值是从长数组中提取的。以前,这是一个 MySQL 查询,在过去 5 年中一直运行良好,因此该数组没有任何问题。正如你所看到的,在故障排除中,我添加了变量 $FCount、$VCount 和 $PCount;确保计数相同,尽管这相当愚蠢,因为无论如何,它们都会在循环过程中进行计数。作为双重检查,您可以在我的异常代码中看到我添加了计数和字符串作为第二个保证,并对它们进行了多次计数。我什至免除了具有空白值的字段。我对 PDO 相当陌生,不知道这里出了什么问题。<?php    $DSN = "mysql:host=$HOST;dbname=$DBName;charset=utf8";    $Options = array(PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION, PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC, PDO::ATTR_EMULATE_PREPARES => false,);    try{$pdo = new PDO($DSN, $USER, $PASSWORD, $Options);}    catch (PDOException $e)    {        $LogData = "\n".date('Y-m-d H:i').' '.$_SESSION[PageName].' '.$e->getMessage().' '.(int)$e->getCode();        error_log($LogData, 3, "error.log");        exit('<h2 style="width:90%; border:2px solid #FF0000; padding:15px;">Server Connect Error! [1]</h2>');    }    $FCount = 0;    $VCout = 0;    $PCount = 0;    foreach($RateVars as $key => $value)    {        if(!empty($value))        {            $FieldString .= trim($key) . ','; $FCount++;            $VarString .= '"' . addslashes(trim($value)) . '",'; $VCount++;            $PrepString .= '?, '; $PCount++;        }    }    $FieldString    .= 'Server';    $VarString      .= '"'.$Node.'"';    $PrepString     .= '?';    $sql = 'INSERT INTO Archive ('.$FieldString.') VALUES ('.$PrepString.')';    $stmt = $pdo->prepare($sql);    try {$stmt->execute(array($VarString));}    catch (PDOException $e)?>添加注释简短示例(这里有 72 个变量),从我的错误日志打印出 $sql: INSERT INTO RateArchive (EstType,hszip,hczip,wswxds,etc...) VALUES ("W","58102"," 58652","000050000000000000","0500000000000000"等) 在回答下面的评论时,$Node 的值是“DEV”,这正是它在值字符串末尾的显示方式。
查看完整描述

1 回答

?
慕斯王

TA贡献1864条经验 获得超2个赞

每个参数都需要是传递给 的数组中的单独元素$stmt->execute(),它不应该是单个逗号分隔的字符串。


<?php

$DSN = "mysql:host=$HOST;dbname=$DBName;charset=utf8";

$Options = array(PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION, PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC, PDO::ATTR_EMULATE_PREPARES => false,);

try{$pdo = new PDO($DSN, $USER, $PASSWORD, $Options);}

catch (PDOException $e)

{

    $LogData = "\n".date('Y-m-d H:i').' '.$_SESSION[PageName].' '.$e->getMessage().' '.(int)$e->getCode();

    error_log($LogData, 3, "error.log");

    exit('<h2 style="width:90%; border:2px solid #FF0000; padding:15px;">Server Connect Error! [1]</h2>');

}

$FCount = 0;

$VCount = 0;

$PCount = 0;


$PrepString = str_repeat("?, ", count($RateVars));

$FieldString = implode(',', array_keys($RateVars));

$PrepString .= '?';

$FieldString .= ', Server';

$ValArray = array_values($RateVars);

$ValArray[] = $Node;

$sql = 'INSERT INTO Archive ('.$FieldString.') VALUES ('.$PrepString.')';

$stmt = $pdo->prepare($sql);

try {

    $stmt->execute($ValArray);

} catch (PDOException $e)

{

    $ErrorMsg = "DataBase Error in Save to Archive"; $Status=1;

    $LogData = "\n".date('Y-m-d H:i').' '.$_SESSION[PageName].' '.$ErrorMsg.' '.$e->getMessage().' '.(int)$e->getCode();

    $LogData .= "\n".'F: '.$FCount.' V: '.$VCount.' P: '.$PCount;

    $LogData .= "\n".'F: '.$FieldString."\n".' V: '.implode(',', $ValArray)."\n".' P: '.$PrepString."\n".$sql;

    error_log($LogData, 3, "error.log");

}


?>


查看完整回答
反对 回复 2023-08-11
  • 1 回答
  • 0 关注
  • 105 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信