In the provided code, the error arises when executing a multiple insert query due to a parameter mismatch between the values being inserted and the expected number of parameters in the query.
The code generates an array of placeholders ($values) based on the count of matches ($matches). However, if there's already content in the $values array, it can lead to a discrepancy in counts, causing the error.
To address this issue:
Always initialize the $values array to an empty state before using it in the loop.
$values = [];
$matches = array('1'); $count = count($matches); $values = []; for($i = 0; $i < $count; ++$i) { $values[] = '(?)'; } $sql = "INSERT INTO hashes (hash) VALUES " . implode(', ', $values) . " ON DUPLICATE KEY UPDATE hash=values(hash)"; $stmt = $dbh->prepare($sql); $data = $stmt->execute($matches);
By implementing these changes, the code should execute successfully without encountering the parameter mismatch error.
The above is the detailed content of How to Fix 'Invalid Parameter Number' Errors in MySQL Multiple INSERT Queries?. For more information, please follow other related articles on the PHP Chinese website!