Výukový program PHP

PHP HOME Úvod do PHP Instalace PHP Syntaxe PHP Komentáře PHP PHP proměnné PHP Echo / tisk Datové typy PHP PHP řetězce PHP čísla PHP matematika Konstanty PHP Operátoři PHP PHP If...Else...Elseif Přepínač PHP PHP smyčky Funkce PHP Pole PHP PHP Superglobals PHP RegEx

Formuláře PHP

Manipulace s formuláři PHP Ověření formuláře PHP Je vyžadován formulář PHP Adresa URL / e-mail PHP formuláře Formulář PHP dokončen

PHP pro pokročilé

Datum a čas PHP Zahrnout PHP Práce se soubory PHP PHP soubor otevřít/číst Vytvoření/zápis souboru PHP Nahrání souboru PHP PHP soubory cookie PHP relace PHP filtry Pokročilé filtry PHP Funkce zpětného volání PHP PHP JSON Výjimky PHP

PHP OOP

PHP Co je OOP PHP třídy/objekty PHP konstruktor PHP destruktor Modifikátory přístupu PHP Dědičnost PHP Konstanty PHP Abstraktní třídy PHP Rozhraní PHP Vlastnosti PHP Statické metody PHP Statické vlastnosti PHP Jmenné prostory PHP PHP Iterables

Databáze MySQL

Databáze MySQL Připojení MySQL MySQL Vytvořte DB Vytvořit tabulku MySQL Vložit data MySQL MySQL Get Last ID MySQL Insert Multiple MySQL připraveno MySQL Select Data Kde MySQL Pořadí MySQL podle Vymazání dat MySQL Aktualizace dat MySQL Limit dat MySQL

PHP XML

PHP analyzátory XML PHP SimpleXML Parser PHP SimpleXML - Získejte PHP XML expat PHP XML DOM

PHP - AJAX

Úvod do AJAXu AJAX PHP Databáze AJAX AJAX XML AJAX Live Search Anketa AJAX

Příklady PHP

Příklady PHP PHP kompilátor PHP kvíz Cvičení PHP Certifikát PHP

Reference PHP

Přehled PHP Pole PHP Kalendář PHP Datum PHP Adresář PHP Chyba PHP Výjimka PHP Souborový systém PHP PHP filtr PHP FTP PHP JSON Klíčová slova PHP PHP Libxml PHP Mail PHP matematika PHP Různé PHP MySQLi Síť PHP Ovládání výstupu PHP PHP RegEx PHP SimpleXML PHP stream PHP řetězec PHP Variable Handling PHP XML Parser PHP zip Časová pásma PHP

Připojení PHP k MySQL


PHP 5 a novější mohou pracovat s databází MySQL pomocí:

  • Rozšíření MySQLi ("i" znamená vylepšené)
  • PDO (PHP Data Objects)

Dřívější verze PHP používaly rozšíření MySQL. Toto rozšíření však bylo v roce 2012 ukončeno.


Mám používat MySQLi nebo PDO?

Pokud potřebujete krátkou odpověď, byla by to „Cokoli chcete“.

MySQLi i PDO mají své výhody:

PDO bude fungovat na 12 různých databázových systémech, zatímco MySQLi bude fungovat pouze s databázemi MySQL.

Pokud tedy musíte svůj projekt přepnout na jinou databázi, PDO tento proces zjednoduší. Stačí změnit připojovací řetězec a pár dotazů. S MySQLi budete muset přepsat celý kód – včetně dotazů.

Oba jsou objektově orientované, ale MySQLi nabízí i procedurální API.

Oba podporují připravená prohlášení. Připravené příkazy chrání před SQL injection a jsou velmi důležité pro zabezpečení webových aplikací.


Příklady MySQL v syntaxi MySQLi i PDO

V této a v následujících kapitolách demonstrujeme tři způsoby práce s PHP a MySQL:

  • MySQLi (objektově orientované)
  • MySQLi (procedurální)
  • CHOP

Instalace MySQLi

Pro Linux a Windows: Rozšíření MySQLi se ve většině případů automaticky nainstaluje, když je nainstalován balíček php5 mysql.

Podrobnosti o instalaci najdete na: http://php.net/manual/en/mysqli.installation.php


Instalace PDO

Podrobnosti o instalaci najdete na: http://php.net/manual/en/pdo.installation.php



Otevřete připojení k MySQL

Než budeme moci přistupovat k datům v databázi MySQL, musíme být schopni se připojit k serveru:

Příklad (Objektově orientovaný MySQLi)

<?php
$servername = "localhost";
$username = "username";
$password = "password";

// Create connection
$conn = new mysqli($servername, $username, $password);

// Check connection
if ($conn->connect_error) {
  die("Connection failed: " . $conn->connect_error);
}
echo "Connected successfully";
?>

Poznámka k výše uvedenému objektově orientovanému příkladu:

$connect_error byl nefunkční až do PHP 5.2.9 a 5.3.0. Pokud potřebujete zajistit kompatibilitu s verzemi PHP staršími než 5.2.9 a 5.3.0, použijte místo toho následující kód:

// Zkontrolujte připojení
if (mysqli_connect_error()) {
  die("Připojení k databázi selhalo: " . mysqli_connect_error());
}

Příklad (Procedurální MySQLi)

<?php
$servername = "localhost";
$username = "username";
$password = "password";

// Create connection
$conn = mysqli_connect($servername, $username, $password);

// Check connection
if (!$conn) {
  die("Connection failed: " . mysqli_connect_error());
}
echo "Connected successfully";
?>

Příklad (PDO)

<?php
$servername = "localhost";
$username = "username";
$password = "password";

try {
  $conn = new PDO("mysql:host=$servername;dbname=myDB", $username, $password);
  // set the PDO error mode to exception
  $conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
  echo "Connected successfully";
} catch(PDOException $e) {
  echo "Connection failed: " . $e->getMessage();
}
?>

Poznámka: Ve výše uvedeném příkladu PDO jsme také specifikovali databázi (myDB) . PDO vyžaduje platnou databázi pro připojení. Pokud není zadána žádná databáze, je vyvolána výjimka.

Tip: Velkou výhodou PDO je, že má třídu výjimek pro řešení jakýchkoli problémů, které se mohou vyskytnout v našich databázových dotazech. Pokud je v bloku try{ } vyvolána výjimka, skript se zastaví a přejde přímo k prvnímu bloku catch(){ }.


Zavřete připojení

Po skončení skriptu se připojení automaticky ukončí. Chcete-li ukončit připojení dříve, použijte následující:

Objektově orientované MySQLi:

$conn->close();

Postup MySQLi:

mysqli_close($conn);

CHOP:

$conn = null;