sql >> Databáze >  >> RDS >> Mysql

Připravené příkazy MySQL

Použijte PDO (PHP Data Objects) pro připojení k vaší databázi MySQL. Tato metoda zajistí, že veškerý databázový vstup bude vždy považován za textové řetězce a nikdy nebudete muset provádět žádné ruční escapování.

To v kombinaci se správným použitím html_entities() k zobrazení dat z vaše databáze je solidní a dobrý způsob, jak chránit vaši stránku před injekcí. Ke zpracování všech připojení k databázi v mých projektech vždy používám PDO.

Vytvořit databázový objekt (a v tomto případě vynutit určité kódování znaků):

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();
}

Pak to použijte takto:

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

nebo

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

a se zástupnými znaky:

$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!";
}

Přečtěte si více:

Jak mohu zabránit vkládání SQL v PHP?

Kdy *ne* použít připravená prohlášení?

jak bezpečná jsou prohlášení připravená pro CHOP

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



  1. Jak vytvořit VARRAY jako člena bloku PL/SQL v databázi Oracle

  2. Jak exportovat data pomocí Oracle SQL Developer?

  3. Špatné návyky:Vyhýbání se NULL v SQL Server

  4. Proč dotaz Microsoft SQL Server 2012 trvá několik minut oproti JDBC 4.0, ale sekundy v Management Studio?