sql >> Database >  >> RDS >> Mysql

Voeg een groot aantal variabelen in de tabel in met PDO

Dynamisch voorbereide zoekopdrachten

U kunt uw zoekopdracht dynamisch opbouwen vanuit de $_POST-array:

Maar vertrouw NOOIT gebruikersinvoer, wat betekent dat u er niet op kunt vertrouwen dat gegevens in $_POST geldige kolomnamen bevatten.

1. De postgegevens opschonen

U kunt een array van kolomnamen op de witte lijst definiëren $whitelist = array('field1', 'field2', ...) , en gebruik dan:

$data = array_intersect_key($_POST, array_flip($whitelist));

om de kruising te vinden tussen de kolommen op de witte lijst en uw $_POST-array. (Bedankt @BillKarwin)

2. Stel de zoekopdracht samen

private function buildInsertSql($data, $table) {
    $columns = "";  
    $holders = "";  
    foreach ($data as $column => $value) {  
       $columns .= ($columns == "") ? "" : ", ";  
       $columns .= $column;  
       $holders .= ($holders == "") ? "" : ", ";  
       $holders .= ":$column";  
    }  
    $sql = "INSERT INTO $table ($columns) VALUES ($holders)";  
    return $sql; 
}

Dit geeft je een SQL-statement van de vorm:

$sql = INSERT INTO directory (field1, field2) VALUES (:field1, :field2)

en bereid de verklaring voor:

$stmt = $dbh->prepare($sql);

3. Bindparameters

U kunt dan dynamisch parameters aan de tijdelijke aanduidingen binden:

foreach ($data as $placeholder => $value) {
    $stmt->bindValue(":$placeholder", $value);
 }

en voer het uit:

$stmt->execute();

Een beetje geavanceerder...



  1. Meerdere en enkele indexen

  2. Query om de tabelgrootte in de Oracle-database te controleren

  3. ...mysql2/mysql2.so:[BUG] Segmentatiefout ruby ​​2.0.0p247

  4. Hoe groepeer ik op continue bereiken