Wie PHP PDO zum Betreiben der Datenbank verwendet

王林
Freigeben: 2023-06-18 08:38:01
Original
1542 Leute haben es durchsucht

In der Webentwicklung ist die Datenbank eine sehr wichtige Komponente. Wie andere Programmiersprachen bietet auch die PHP-Sprache viele Möglichkeiten, die Datenbank zu betreiben. Unter diesen ist PDO (PHP Data Object) eine der gängigen Methoden zum Betreiben von Datenbanken in PHP. Es bietet eine einheitliche, einfache, flexible und sichere Methode für den Zugriff auf verschiedene Datenbanksysteme. In diesem Artikel wird vorgestellt, wie PHP PDO zum Betrieb der Datenbank verwendet.

1. Vorteile von PDO

Die Vorteile der Verwendung von PDO zum Betreiben der Datenbank sind wie folgt:

  1. Das Programm ist hochgradig portierbar: Die Verwendung von PDO zum Betreiben der Datenbank ist portabler und kann auf verschiedenen Datenbanken ausgeführt werden, ohne dass dies erforderlich ist Nehmen Sie größere Änderungen am Programm vor.
  2. Hohe Sicherheit: PDO unterstützt die Verarbeitung von Befehlszeilenparametern und kann SQL-Injection-Angriffe wirksam verhindern.
  3. Objektorientiert: PDO ist objektorientiert und kann die OOP-Programmierung komfortabler machen.
  4. Gute Leistung: PDO unterstützt vorbereitete Anweisungen und Datenbindung, was die Abfrageeffizienz erheblich verbessern und dadurch die Programmleistung verbessern kann.

2. Verwenden Sie PDO, um eine Verbindung zur Datenbank herzustellen.

Bevor Sie PDO zum Betreiben der Datenbank verwenden, müssen Sie zunächst eine Verbindung zur Datenbank herstellen. Der Code zum Herstellen einer Verbindung zur Datenbank lautet wie folgt:

//设置数据库连接信息
$dsn = 'mysql:host=localhost;dbname=testdb';
$username = 'root';
$password = 'root';
$options = [
    //错误模式:在发生错误时抛出异常
    PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION,
    //默认返回关联数组
    PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC
];
//创建PDO对象
$pdo = new PDO($dsn, $username, $password, $options);
Nach dem Login kopieren

Unter diesen steht $dsn für Datenbanktyp, Hostnamen, Datenbanknamen und andere Informationen, $username für Benutzernamen, $password für Passwort und $options für Einstellungen, z Festlegen des Fehlermodus, des Rückgabedatentyps usw. . Beim Herstellen einer Verbindung zur Datenbank können Sie auch andere Optionen festlegen, z. B.:

$options = [
    //设置字符集
    PDO::MYSQL_ATTR_INIT_COMMAND => 'SET NAMES utf8',
    //关闭持久连接
    PDO::ATTR_PERSISTENT => false,
    //设置超时时间
    PDO::ATTR_TIMEOUT => 10,
    //设置返回数据类型为对象
    PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_OBJ,
    // 禁用预处理语句的模拟
    PDO::ATTR_EMULATE_PREPARES => false,
];
Nach dem Login kopieren

3. PDO implementiert Vorgänge zum Hinzufügen, Löschen, Ändern und Überprüfen.

Nach dem Herstellen einer Verbindung zur Datenbank können Sie die Datenbank hinzufügen, löschen, ändern und überprüfen . Zu den häufig verwendeten Vorgängen gehören: Einfügen von Daten, Aktualisieren von Daten, Löschen von Daten und Abfragen von Daten.

  1. Daten einfügen

Der Code zum Einfügen von Daten in die Datenbank mithilfe von PDO lautet wie folgt:

//插入数据
$sql = "INSERT INTO `users` (`name`,`age`,`email`) VALUES (:name,:age,:email)";
$name = 'Tom';
$age = 23;
$email = 'tom@example.com';
$stmt = $pdo->prepare($sql);
$stmt->bindValue(':name', $name);
$stmt->bindValue(':age', $age);
$stmt->bindValue(':email', $email);
$stmt->execute();
Nach dem Login kopieren

Unter anderem ist $sql die SQL-Anweisung zum Einfügen von Daten, die zur Vermeidung von SQL-Injection-Angriffen verwendet wird. Die Methode „bindValue()“ bindet den Parameter an den Platzhalter mit dem angegebenen Namen und ruft dann die Methode „execute()“ auf, um die Abfrage an die Datenbank zu senden.

  1. Daten aktualisieren

Der Code zum Aktualisieren von Daten mithilfe von PDO lautet wie folgt:

//更新数据
$sql = "UPDATE `users` SET `age` = :age WHERE `name` = :name";
$name = 'Tom';
$age = 24;
$stmt = $pdo->prepare($sql);
$stmt->bindValue(':name', $name);
$stmt->bindValue(':age', $age);
$stmt->execute();
Nach dem Login kopieren

Unter anderem ist $sql die SQL-Anweisung zum Aktualisieren der Daten. Die Parameterbindung wird verwendet, um SQL-Injection-Angriffe zu vermeiden. Die Methode „bindValue()“ bindet den Parameter an den Platzhalter mit dem angegebenen Namen und ruft dann die Methode „execute()“ auf, um die Abfrage an die Datenbank zu senden.

  1. Daten löschen

Der Code zum Löschen von Daten mithilfe von PDO lautet wie folgt:

//删除数据
$sql = "DELETE FROM `users` WHERE `name` = :name";
$name = 'Tom';
$stmt = $pdo->prepare($sql);
$stmt->bindValue(':name', $name);
$stmt->execute()
Nach dem Login kopieren

Unter anderem ist $sql die SQL-Anweisung zum Löschen von Daten. Die Parameterbindung wird verwendet, um SQL-Injection-Angriffe zu vermeiden. Die Methode bindValue() bindet den Parameter an den Platzhalter mit dem angegebenen Namen und ruft dann die Methodeexecute() auf, um die Abfrage an die Datenbank zu senden.

  1. Daten abfragen

Der Code zum Abfragen von Daten mithilfe von PDO lautet wie folgt:

//查询数据
$sql = "SELECT * FROM `users` WHERE `age` > :age";
$age = 20;
$stmt = $pdo->prepare($sql);
$stmt->bindValue(':age', $age);
$stmt->execute();
$rows = $stmt->fetchAll();
Nach dem Login kopieren

Unter anderem ist $sql die SQL-Anweisung zum Abfragen von Daten. Die Parameterbindung wird verwendet, um SQL-Injection-Angriffe zu vermeiden. Die Methode bindValue() bindet den Parameter an den Platzhalter mit dem angegebenen Namen und ruft dann die Methodeexecute() auf, um die Abfrage an die Datenbank zu senden. Die Methode fetchAll() gibt die Abfrageergebnisse als mehrdimensionales Array zurück.

Da PDO das Abrufen von drei Arten von Ergebnissen unterstützt: assoziatives Array, numerisches Array und Objekt, müssen Sie beim Abfragen der Ergebnisse den Typ der Abruferfassung festlegen, zum Beispiel:

//查询并获取关联数组
$rows = $stmt->fetchAll(PDO::FETCH_ASSOC);
 
//查询并获取数字数组
$rows = $stmt->fetchAll(PDO::FETCH_NUM);
 
//查询并获取对象数组
$rows = $stmt->fetchAll(PDO::FETCH_OBJ);
Nach dem Login kopieren

4. PDO implementiert die Transaktionsverarbeitung

PDO unterstützt Bei der Transaktionsverarbeitung können Sie die Methoden beginTransaction(), commit() und rollback() verwenden, um Transaktions-Commit- und Rollback-Vorgänge zu implementieren.

try {
    //开启事务
    $pdo->beginTransaction();
    //执行增删改操作语句
    $pdo->exec($sql1);
    $pdo->exec($sql2);
    $pdo->exec($sql3);
    //提交事务
    $pdo->commit();
} catch (Exception $e) {
    //回滚事务
    $pdo->rollback();
}
Nach dem Login kopieren

Das Obige ist eine grundlegende Einführung in die Verwendung von PDO zum Betrieb einer Datenbank. Beim Betrieb einer Datenbank mit PDO müssen Sie einige Punkte beachten:

  1. Verwenden Sie Parameterbindung, um SQL-Injection-Angriffe zu vermeiden.
  2. Setzen Sie den Fehlermodus der PDO-Ausnahme auf AUSNAHME, um Ausnahmen einfach abzufangen.
  3. Durch die Verwendung der Prepare()-Methode zum Ausführen von Operationsanweisungen kann die Ergebnismenge zwischengespeichert werden, um die Abfrageeffizienz zu verbessern.
  4. Durch die Vorverarbeitung von Anweisungen und die Datenbindung können wiederholte Arbeiten zur Analyse und Optimierung von Anweisungen vermieden werden, wodurch eine höhere Abfrageeffizienz erreicht wird.
  5. Aktivieren Sie die Transaktionsverarbeitung, um Datenintegrität und -konsistenz sicherzustellen.

Kurz gesagt ist die Verwendung von PDO zum Betreiben der Datenbank eine relativ bequeme und effektive Möglichkeit, leistungsstarke Datenbankzugriffsfunktionen für Webanwendungen bereitzustellen.

Das obige ist der detaillierte Inhalt vonWie PHP PDO zum Betreiben der Datenbank verwendet. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
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
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage