Od czasu do czasu pojawiają się pytania dotyczące łączenia się z bazą danych.
Większość odpowiedzi nie jest tak, jak to robię, lub po prostu mogę nie uzyskać poprawnych odpowiedzi. Tak czy inaczej; Nigdy o tym nie myślałem, ponieważ sposób, w jaki to robię, działa na mnie.
Ale oto szalona myśl; Może robię to wszystko źle, a jeśli tak jest; Naprawdę chciałbym wiedzieć, jak poprawnie połączyć się z bazą danych MySQL za pomocą PHP i PDO i uczynić ją łatwo dostępną.
Oto jak to robię:
Po pierwsze, oto moja struktura plików (rozebrana) :
public_html/
* index.php
* initialize/
-- load.initialize.php
-- configure.php
-- sessions.php
index.php
Na samej górze mam require('initialize/load.initialize.php');
.
load.initialize.php
# site configurations
require('configure.php');
# connect to database
require('root/somewhere/connect.php'); // this file is placed outside of public_html for better security.
# include classes
foreach (glob('assets/classes/*.class.php') as $class_filename){
include($class_filename);
}
# include functions
foreach (glob('assets/functions/*.func.php') as $func_filename){
include($func_filename);
}
# handle sessions
require('sessions.php');
Wiem, że istnieje lepszy lub bardziej poprawny sposób włączania zajęć, ale nie pamiętam, co to było. Nie miałem jeszcze czasu, żeby się temu przyjrzeć, ale myślę, że to było coś z tym autoload
. coś w tym stylu...
configure.php
Tutaj po prostu nadpisuję niektóre właściwości php.ini i wykonuję inną globalną konfigurację witryny
connect.php
Umieściłem połączenie w klasie, aby inne klasy mogły ją rozszerzyć ...
class connect_pdo
{
protected $dbh;
public function __construct()
{
try {
$db_host = ' '; // hostname
$db_name = ' '; // databasename
$db_user = ' '; // username
$user_pw = ' '; // password
$con = new PDO('mysql:host='.$db_host.'; dbname='.$db_name, $db_user, $user_pw);
$con->setAttribute( PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION );
$con->exec("SET CHARACTER SET utf8"); // return all sql requests as UTF-8
}
catch (PDOException $err) {
echo "harmless error message if the connection fails";
$err->getMessage() . "<br/>";
file_put_contents('PDOErrors.txt',$err, FILE_APPEND); // write some details to an error-log outside public_html
die(); // terminate connection
}
}
public function dbh()
{
return $this->dbh;
}
}
# put database handler into a var for easier access
$con = new connect_pdo();
$con = $con->dbh();
//
Wierzę, że jest miejsce na ogromne ulepszenia, odkąd niedawno zacząłem uczyć się OOP i używać PDO zamiast mysql.
Właśnie skorzystałem z kilku samouczków dla początkujących i wypróbowałem różne rzeczy ...
session.php
Oprócz obsługi zwykłych sesji, inicjalizuję również niektóre klasy w sesję taką jak ta:
if (!isset($_SESSION['sqlQuery'])){
session_start();
$_SESSION['sqlQuery'] = new sqlQuery();
}
W ten sposób ta klasa jest dostępna w każdym miejscu. To może nie być dobra praktyka (?) ... W
każdym razie to podejście pozwala mi robić z każdego miejsca:
echo $_SESSION['sqlQuery']->getAreaName('county',9); // outputs: Aust-Agder (the county name with that id in the database)
Wewnątrz mojej sqlQuery
- klasy , która jest extends
moją connect_pdo
- klasą , mam funkcję publiczną o nazwie, getAreaName
która obsługuje żądanie do mojej bazy danych.
Myślę, że całkiem nieźle.
Działa jak urok.
Tak to właśnie robię.
Poza tym za każdym razem, gdy potrzebuję pobrać coś z mojej bazy danych spoza klasy, po prostu robię coś podobnego do tego:
$id = 123;
$sql = 'SELECT whatever FROM MyTable WHERE id = :id';
$qry = $con->prepare($sql);
$qry -> bindParam(':id', $id, PDO::PARAM_INT);
$qry -> execute();
$get = $qry->fetch(PDO::FETCH_ASSOC);
Ponieważ umieściłem połączenie w zmiennej wewnątrz connect_pdo.php , po prostu nawiązałem do tego i jestem gotowy . To działa. Otrzymuję oczekiwane rezultaty ...
Ale niezależnie od tego; Byłbym wdzięczny, gdybyście mogli mi powiedzieć, że jestem daleko. Co powinienem zrobić zamiast tego, obszary, które mógłbym lub powinienem zmienić w celu poprawy itp.
Chętnie się uczę ...