Wie ersetzt man MySQL-Funktionen durch PDO: Ein Leitfaden zur modernen Datenbankkonnektivität in PHP?

Barbara Streisand
Freigeben: 2024-11-16 04:07:50
Original
928 Leute haben es durchsucht

How to Replace MySQL Functions with PDO: A Guide to Modern Database Connectivity in PHP?

So ersetzen Sie MySQL-Funktionen durch PDO

Einführung:

Die MySQL-Erweiterung ist veraltet in PHP und sollte für die Datenbankkonnektivität entweder durch MySQLi oder PDO_MySQL ersetzt werden. PDO (PHP Data Objects) bietet eine moderne, objektorientierte Schnittstelle für den Zugriff auf mehrere Datenbanken.

Verbindung zu MySQL- und MSSQL-Datenbanken:

MySQL:

$dsn = 'mysql:dbname=database_name;host=localhost';
$user = 'username';
$password = 'password';

$dbh = new PDO($dsn, $user, $password);
Nach dem Login kopieren

MSSQL:

$dsn = 'sqlsrv:Server=localhost;Database=database_name';
$user = 'username';
$password = 'password';

$dbh = new PDO($dsn, $user, $password);
Nach dem Login kopieren

Durchführen von Abfragen:

PDO verwendet vorbereitete Anweisungen für die Abfrageausführung , schützt vor SQL-Injection.

Beispiel-SQL:

$SQL = 'SELECT ID, EMAIL FROM users WHERE user = :username';
Nach dem Login kopieren

Ausführen einer Abfrage:

// Prepare statement with array of named variables
$result = $dbh->prepare($SQL);
$result->execute([':username' => $username]);

// OR

// Prepare statement with named placeholder indicator
$result = $dbh->prepare($SQL);
$result->bindValue(':username', $username);
$result->execute();
Nach dem Login kopieren

Ergebnisse abrufen:

// Fetch a single row as an array
$row = $result->fetch();

// Fetch all rows as an array
$rows = $result->fetchAll();
Nach dem Login kopieren

Verwenden einer Hilfsklasse:

Um Datenbankinteraktionen zu vereinfachen, sollten Sie die Verwendung einer Klasse wie der folgenden in Betracht ziehen:

class PDOConnection {
    public $connection;

    public function __construct($dsn, $username, $password) {
        $this->connection = new PDO($dsn, $username, $password);
        $this->connection->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
    }

    public function query($SQL) {
        return $this->connection->query($SQL);
    }

    public function prepare($SQL, $params = []) {
        $result = $this->connection->prepare($SQL);
        $result->execute($params);
        return $result;
    }
}
Nach dem Login kopieren

Beispielverwendung:

$db = new PDOConnection($dsn, $user, $password);

$SQL = 'SELECT ID, EMAIL FROM users WHERE user = :username';
$result = $db->prepare($SQL, ['username' => $username]);

while ($row = $result->fetch()) {
    echo $row['ID'] . ' ' . $row['EMAIL'];
}
Nach dem Login kopieren

Das obige ist der detaillierte Inhalt vonWie ersetzt man MySQL-Funktionen durch PDO: Ein Leitfaden zur modernen Datenbankkonnektivität in PHP?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage