データベース テーブルに複数のレコードを挿入しようとすると、「パラメータ番号が無効です:パラメーターが定義されていません" エラー。これは、クエリで指定されたパラメータの数が、入力として指定された値の数と一致しない場合に発生します。
提供されたコード スニペット内:
$matches = array('1'); $count = count($matches); for($i = 0; $i < $count; ++$i) { $values[] = '(?)'; } // Build query $q = $this->dbc->prepare("INSERT INTO hashes (hash) VALUES " . implode(', ', $values) . " ON DUPLICATE KEY UPDATE hash = hash"); $q->execute($matches);
目標は、準備されたステートメントを使用して、$matches の値をハッシュ テーブルに挿入することです。ただし、$values 配列内のプレースホルダー パラメーター (?) の数が $matches 内の実際のデータに対応していないために、エラーが発生します。
この問題を解決するには、以下:
$matches = array('1'); $values = []; $count = count($matches); for($i = 0; $i < $count; ++$i) { $values[] = '(?)'; } // Insert query with named parameters (:hash) $sql = "INSERT INTO hashes (hash) VALUES (:hash) ON DUPLICATE KEY UPDATE hash = VALUES(:hash)"; $stmt = $dbh->prepare($sql); $data = $stmt->execute([':hash' => $matches]);
以上が複数の挿入クエリで「無効なパラメータ番号」が返されるのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。