Oubliez bindParam
, utilisez simplement execute
et passez-lui les valeurs de $array
:
$STH->execute($array);
Vous pouvez également supprimer complètement les paramètres nommés pour simplifier un peu votre code :
$columnString = implode(',', array_keys($array));
$valueString = implode(',', array_fill(0, count($array), '?'));
$STH = $core->dbh->prepare("INSERT INTO table ({$columnString}) VALUES ({$valueString})");
$STH->execute(array_values($array));