Apabila cuba memasukkan berbilang rekod ke dalam jadual pangkalan data, anda mungkin menghadapi "Nombor parameter tidak sah: parameter tidak ditakrifkan" ralat. Ini berlaku apabila bilangan parameter yang dinyatakan dalam pertanyaan tidak sepadan dengan bilangan nilai yang diberikan sebagai input.
Dalam coretan kod yang disediakan:
$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);
Matlamatnya adalah untuk memasukkan nilai dalam $matches ke dalam jadual cincang, menggunakan pernyataan yang disediakan. Walau bagaimanapun, ralat berlaku kerana bilangan parameter pemegang tempat (?) dalam tatasusunan $values tidak sepadan dengan data sebenar dalam $matches.
Untuk menyelesaikan isu ini, pastikan berikut:
$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]);
Atas ialah kandungan terperinci Mengapa Pertanyaan Sisipan Berbilang Saya Mengembalikan 'Nombor Parameter Tidak Sah'?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!