PHP PDO 无效参数编号 : parameter was not defined using Q-mark parameters

标签 php mysql pdo

编辑:您不能在标题中使用“问题”一词。 Q-mark意为“问号”

编辑 2:意识到我应该从虚拟客户记录中删除我的个人联系信息

我正在尝试制作一些基本功能来减少最近项目的维护。其中包括以下简单函数,因此我可以在以后将列添加到数据库而无需更改我的更新查询:

function update( $table, $fields ) {
    global $db; // A slightly modified PDO object
    if( count( $fields ) > 0 ) {
        $query = "UPDATE `" . $table . "` SET ";
        foreach( $customer as $key => $value ) {
            $query .= "`" . $key . "` = ?, ";
        }
        $query = substr( $query, 0, -2 );
        $query .= " WHERE `id` = " . $_REQUEST['id'];
        $db->prepare( $query );
        $db->execute( $fields );
    } else { return true; }
}

当我传递一个或两个字段时,此函数可以正常工作,但当我尝试传递更多字段时,它失败了。这是查询、$fields 的值以及我收到的错误:

查询:

string 'UPDATE `customers` SET `5v` = ?, `contactaddress` = ?, `contactaddress2` = ?, `contactcity` = ?, `contactemail` = ?, `contactname` = ?, `contactphone` = ?, `contactstate` = ?, `contactzip` = ?, `corrugated` = ?, `name` = ?, `permalok` = ?, `residential` = ?, `secureseam` = ?, `tax` = ? WHERE `id` = 1' (length=301)

$字段:

array
  '5v' => string '120' (length=3)
  'contactaddress' => string '999 Street Dr' (length=13)
  'contactaddress2' => string 'Apt 2' (length=7)
  'contactcity' => string 'City' (length=9)
  'contactemail' => string 'steven.abarnett@gmail.com' (length=25)
  'contactname' => string 'Steven Barnett' (length=14)
  'contactphone' => string '(555) 555-5555' (length=14)
  'contactstate' => string 'KY' (length=2)
  'contactzip' => string '55555' (length=5)
  'corrugated' => string '90' (length=2)
  'name' => string 'Steven's Metals' (length=15)
  'permalok' => string '130' (length=3)
  'residential' => string '100' (length=3)
  'secureseam' => string '130' (length=3)
  'tax' => string '6' (length=1)

错误:

string 'Statement execution failed: SQLSTATE[HY093]: Invalid parameter number: parameter was not defined' (length=96)

用谷歌搜索这个错误,听起来像是named 参数的问题,而不是question-mark 参数。为什么会出现此错误?

更新:

我一直在继续调试和试验并跟踪错误,我发现不是语句执行失败,而是之后尝试获取结果。

在我修改后的 PDO 对象中,我的 execute() 方法中有以下代码:

    // Load from database
    try {
        $this->stmt->execute( $args );
        $this->lastid = $this->dbh->lastInsertId();
        $this->data = $this->stmt->fetchAll();
    } catch (PDOException $e) {
        $this->error = 'Statement execution failed: ' . $e->getMessage();
        return false;
    }

try{} 部分的每一行之间放置 echo 语句表明前两行运行顺利,但第三行抛出异常。

当我调用 PDOStatement::fetchAll() 时,我的查询是否会因一般错误而失败?

最终更新:

事实证明PDO and Mysql haven't been playing nicely for 6 years .一般的解决方案似乎是在每次调用 PDOStatement::execute() 后取消设置 PDOStatement 对象,但这对我不起作用。这个问题源于 MySQL 一次只能打开一个游标指向记录集中的记录,因此另一个建议的解决方案是使用 PDOStatement::fetchAll() 而不是 PDOStatement::fetch() 或调用 PDOStatement::closeCusor()。同样,这对我不起作用。我的问题来自 MySQL 的某些安装,这些安装将在 INSERTUPDATEDELETE 查询期间创建游标(所有这些都不返回任何数据)无法关闭,因为它指向空数据。

我的解决方案是在运行返回数据的查询时只调用 PDOStatement::fetchAll()。我有一个用于缓存的 queryhash 变量(我对 PDO 类所做的重大修改)对于这三种查询类型设置为 false (因为您需要将查询发送到数据库而不是延迟到缓存)。我只是修改了我的 execute() 函数来检查这个变量,并且只在它没有设置为 false 时调用 fetchAll()

最佳答案

您应该使用索引数组而不是关联数组。

array(
    '120',
    '750 Shaker Dr',
    'Apt 505',
    'Lexington', 
    'steven.abarnett@gmail.com', 
    'Steven Barnett', 
    '(859) 402-7760', 
    'KY',
    '40504', 
    '90',
    "Steven's Metals",
    '130',
    '100',
    '130',
    '6'
)

关于PHP PDO 无效参数编号 : parameter was not defined using Q-mark parameters,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10638417/

相关文章:

php - 什么是 PHP 中的对象克隆?

php - 根据程序情况查询运行时构建

php - 使用 php : Multiple user support? 将 android 连接到 mysql 数据库

Php:如何从 MySQL 中单个字段的数组中提取值

php - 通过此 SQL 查询使用 INNER JOIN 和 ON 防止重复

PHP时间间隔至少十天

PHP preg_match 需要确保单词之间只允许一个空格字符

php - 如何替换wordpress中的元标题和元描述?

php - 显示来自数据库的默认 youtube 视频

php - PDO 更新表并加 1 值