Heim > Datenbank > MySQL-Tutorial > Wie kann ich mit PDO_MYSQL oder PDO_MYSQLND mehrere Abfragen in einer einzigen PDO-Anweisung ausführen?

Wie kann ich mit PDO_MYSQL oder PDO_MYSQLND mehrere Abfragen in einer einzigen PDO-Anweisung ausführen?

DDD
Freigeben: 2024-12-17 18:20:11
Original
445 Leute haben es durchsucht

How Can I Execute Multiple Queries in a Single PDO Statement with PDO_MYSQL or PDO_MYSQLND?

Unterstützung mehrerer Abfragen in PDO mit PDO_MYSQL und PDO_MYSQLND

Während PDO normalerweise nicht mehrere Abfragen in einer einzigen Anweisung zulässt, bieten bestimmte Erweiterungen diese Funktionalität:

PDO_MYSQLND

PDO_MYSQLND ersetzt PDO_MYSQL in PHP 5.3. Es dient als Standardtreiber für MySQL PDO. Diese Erweiterung unterstützt die gleichzeitige Ausführung mehrerer Abfragen, sofern die folgenden Bedingungen erfüllt sind:

  • PHP 5.3 oder höher
  • mysqlnd
  • Emulierte vorbereitete Anweisungen aktiviert (PDO::ATTR_EMULATE_PREPARES auf 1 gesetzt, was die Standardeinstellung ist MySQL)

Exec verwenden

Für einfache Abfragen mit konstanten Werten können Sie die Methode exec() verwenden:

$db = new PDO(...);
$db->setAttribute(PDO::ATTR_EMULATE_PREPARES, 0);

$sql = "...";
$db->exec($sql);
Nach dem Login kopieren

Anweisungen verwenden

Für Abfragen mit variablen Daten verwenden Sie vorbereitet Anweisungen:

$db = new PDO(...);
$db->setAttribute(PDO::ATTR_EMULATE_PREPARES, 1);

$sql = "...";
$stmt = $db->prepare($sql);
$stmt->execute([...]);
Nach dem Login kopieren

Denken Sie daran, die Abfrageergebnisse zu durchlaufen, um sie auf Fehler zu prüfen oder Daten zu sammeln.

Hinweis zur Kodierung

Stellen Sie bei der Verwendung emulierter vorbereiteter Anweisungen sicher, dass sie korrekt sind Die Codierung ist im DSN angegeben (verfügbar in PHP 5.3.6 und höher). Eine falsche Codierung kann ein geringes Risiko einer SQL-Injection mit ungewöhnlichen Zeichensätzen mit sich bringen.

Das obige ist der detaillierte Inhalt vonWie kann ich mit PDO_MYSQL oder PDO_MYSQLND mehrere Abfragen in einer einzigen PDO-Anweisung ausführen?. 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
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage