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

MySQL-forberedte erklæringer

Brug PDO (PHP Data Objects) for at oprette forbindelse til din MySQL-database. Denne metode vil sikre, at al databaseinput altid behandles som tekststrenge, og du behøver aldrig at foretage nogen manuel escape.

Dette kombineret med korrekt brug af html_entities() til at vise data fra din database er en solid og god måde at beskytte din side mod indsprøjtning. Jeg bruger altid PDO til at håndtere alle mine databaseforbindelser i mine projekter.

Opret databaseobjekt (og i dette tilfælde håndhæv en bestemt tegnkodning):

try {
    $db = new PDO("mysql:host=[hostname];dbname=[database]",'[username]','[password]');
    $db->setAttribute(PDO::MYSQL_ATTR_INIT_COMMAND, "SET NAMES utf8");
    $db->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION);
    $db->exec('SET NAMES utf8');
} catch (PDOException $e) {
    echo $e->getMessage();
}

Så brug det sådan:

$id = 1;
$q = $db->prepare('SELECT * FROM Table WHERE id = ?');
$q->execute(array($id));
$row = $q->fetch();
echo $row['Column_1'];

eller

$q = $db->prepare('UPDATE Table SET Column_1 = ?, Column_2 = ? WHERE id = ?');
$q->execute(array('Value for Column_1','Value for Column_2',$id));

og med jokertegn:

$search = 'John';
$q = $db->prepare('SELECT * FROM Table WHERE Column_1 LIKE ?');
$q->execute(array('%'.$search.'%'));
$num = $q->rowCount();
if ($num > 0) {
  while ($row = $q->fetch()) {
    echo $row['Column_1'];
  }
} else {
  echo "No hits!";
}

Læs mere:

Hvordan kan jeg forhindre SQL-injektion i PHP?

Hvornår *ikke* at bruge forberedte udsagn?

hvor sikre er PDO-forberedte erklæringer

http://php.net/manual/en/book.pdo.php



  1. Hent værdier fra første og sidste række pr. gruppe

  2. Sådan filtreres poster med samlet funktion COUNT

  3. Udfør produktanalyse ved hjælp af SQL Server Full-Text Search. Del 1

  4. Find ud af, om en værdi indeholder mindst ét ​​numerisk ciffer i Oracle