Povezava z bazo podatkov prek PDO v PHP
Izvedimo povezavo z bazo podatkov prek PDO. Za začetek zapišimo dostope v spremenljivke:
<?php
$host = 'localhost'; // ime gostitelja (praviloma vedno to)
$db = 'test'; // ime baze podatkov
$user = 'root'; // uporabniško ime za dostop do baze
$pass = 'root'; // geslo za dostop do baze
?>
Zdaj moramo oblikovati niz
v posebnem formatu. V tem nizu
moramo navesti tip baze podatkov, ki jo uporabljamo
(praviloma 'mysql'),
ime gostitelja in ime baze podatkov:
<?php
$dsn = "mysql:host=$host; dbname=$db; charset=utf8";
?>
Nato ustvarimo matriko možnosti PDO, ki jih bomo uporabljali v procesu dela (za zdaj se vanje ne poglabljajte):
<?php
$opt = [
PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION,
PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC,
PDO::ATTR_EMULATE_PREPARES => false,
];
?>
Zdaj lahko izvedemo povezavo z bazo podatkov z uporabo zgoraj deklariranih spremenljivk:
<?php
$pdo = new PDO($dsn, $user, $pass, $opt);
?>
Zgoraj navedena koda bo ali vzpostavila povezavo
z bazo podatkov, ali vrgla izjemo.
Zato je pravilneje oviti povezavo
v konstrukcijo try-catch:
<?php
try {
$pdo = new PDO($dsn, $user, $pass, $opt);
echo 'Baza podatkov je povezana';
} catch(PDOException $e) {
echo "Povezava ni uspela: " . $e->getMessage();
}
?>
Popolna koda bo videti takole:
<?php
$host = 'localhost';
$db = 'test';
$user = ''; // uporabniško ime za dostop do baze
$pass = ''; // geslo za dostop do baze
$charset = 'utf8';
$dsn = "mysql:host=$host; dbname=$db; charset=$charset";
$opt = [
PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION,
PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC,
PDO::ATTR_EMULATE_PREPARES => false,
];
try {
$pdo = new PDO($dsn, $user, $pass, $opt);
echo 'Baza podatkov je povezana';
} catch(PDOException $e) {
echo "Povezava ni uspela: " . $e->getMessage();
}
?>
Vzpostavite povezavo z vašo bazo podatkov na način, opisan v lekciji.