sql >> Database teknologi >  >> RDS >> Mysql

Hvordan opretter man en sikker mysql forberedt erklæring i php?

Her er et eksempel, der bruger mysqli (objekt-syntaks - ret let at oversætte til funktionssyntaks, hvis du ønsker det):

$db = new mysqli("host","user","pw","database");
$stmt = $db->prepare("SELECT * FROM mytable where userid=? AND category=? ORDER BY id DESC");
$stmt->bind_param('ii', intval($_GET['userid']), intval($_GET['category']));
$stmt->execute();

$stmt->store_result();
$stmt->bind_result($column1, $column2, $column3);

while($stmt->fetch())
{
    echo "col1=$column1, col2=$column2, col3=$column3 \n";
}

$stmt->close();

Hvis du også vil have en nem måde at få fat i associative arrays (til brug med SELECT *) i stedet for at skulle specificere præcis, hvilke variabler der skal bindes til, er her en praktisk funktion:

function stmt_bind_assoc (&$stmt, &$out) {
    $data = mysqli_stmt_result_metadata($stmt);
    $fields = array();
    $out = array();

    $fields[0] = $stmt;
    $count = 1;

    while($field = mysqli_fetch_field($data)) {
        $fields[$count] = &$out[$field->name];
        $count++;
    }
    call_user_func_array(mysqli_stmt_bind_result, $fields);
}

For at bruge det skal du bare kalde det i stedet for at kalde bind_result:

$stmt->store_result();

$resultrow = array();
stmt_bind_assoc($stmt, $resultrow);

while($stmt->fetch())
{
    print_r($resultrow);
}


  1. phpMyAdmin kaster en #2002 kan ikke logge ind på mysql serveren phpmyadmin

  2. ResultSet#getDate() semantik

  3. pyodbc - meget langsom bulk indsættelseshastighed

  4. Brug af SQL Server Profiler | SQL Server Performance Fejlfinding -5