Mysql
 sql >> Datenbank >  >> RDS >> Mysql

SQLSTATE[HY093]:Ungültige Parameternummer

Gemäß PDO::Prepare

Schalten Sie also entweder den Emulationsmodus ein

$db->setAttribute(PDO::ATTR_EMULATE_PREPARES, TRUE);

oder ändern Sie zu -

$sql = "SELECT * FROM `character` WHERE `name` LIKE :search1  OR `play` LIKE :search2";
$query = $db->prepare($sql); 
$query->execute(array(':search1' => strip_tags($_POST['search']),':search2' => strip_tags($_POST['search'])));

Auch, da Sie LIKE verwenden In Ihrer Abfrage sollten Sie Platzhalter % hinzufügen zu deinen Werten

$query->execute(array(':search1' => "%".strip_tags($_POST['search'])."%",':search2' => "%".strip_tags($_POST['search'])."%"));