ホームページ >データベース >mysql チュートリアル >複数の挿入クエリで「無効なパラメータ番号」が返されるのはなぜですか?

複数の挿入クエリで「無効なパラメータ番号」が返されるのはなぜですか?

Susan Sarandon
Susan Sarandonオリジナル
2024-12-13 18:14:10261ブラウズ

Why Does My Multiple Insert Query Return

エラー: 複数の挿入クエリのパラメータ番号が無効です

データベース テーブルに複数のレコードを挿入しようとすると、「パラメータ番号が無効です:パラメーターが定義されていません" エラー。これは、クエリで指定されたパラメータの数が、入力として指定された値の数と一致しない場合に発生します。

問題の理解

提供されたコード スニペット内:

$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 内の実際のデータに対応していないために、エラーが発生します。

修正

この問題を解決するには、以下:

  1. 配列の初期化: 回避するために、ループの前に常に $values 配列を初期化します。既存の値。
  2. データ数の確認: $values の要素の数が $matches の要素の数と等しいことを確認します。そうでない場合は、ループを調整するか、条件チェックを追加します。
  3. 一意のインデックスの作成: ハッシュ列に一意のインデックスがあるかどうかを確認します。これにより、エントリの重複が防止され、指定された各値が確実に挿入または更新されます。
  4. パラメータ化されたステートメントを使用する: SQL インジェクションとパラメータ バインディングの問題を防ぐために、プリペアド ステートメントを使用します。

$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 サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。