Heim > Backend-Entwicklung > PHP-Tutorial > Wie kann ich meine MySQL-Einfüge-/Aktualisierungsfunktion mithilfe von PDO-vorbereiteten Anweisungen verbessern?

Wie kann ich meine MySQL-Einfüge-/Aktualisierungsfunktion mithilfe von PDO-vorbereiteten Anweisungen verbessern?

Mary-Kate Olsen
Freigeben: 2024-11-23 09:24:43
Original
867 Leute haben es durchsucht

How Can I Improve My MySQL Insert/Update Function Using PDO Prepared Statements?

Hilfsfunktion zum Einfügen/Aktualisieren mit PDO

PDO-vorbereitete Anweisungen zum Einfügen von Daten

Die bereitgestellte Hilfsfunktion dbSet, generiert eine SET-Anweisung zur Verwendung mit herkömmlichen MySQL-Treibern, unterstützt jedoch keine vorbereiteten PDO-Anweisungen. Um dieses Problem zu beheben, kann eine modifizierte Version der Funktion verwendet werden, die die Vorteile von PDO nutzt.

Geänderte Hilfsfunktion

Die aktualisierte dbSet-Funktion benötigt jetzt ein Array von Feldnamen und ein Verweis auf ein Array entsprechender Werte. Es erstellt eine SET-Anweisung mit Platzhaltern für jedes Feld und fügt die Werte dem Wertearray hinzu.

function dbSet($fields, &$values) {
    $set = '';
    $values = array();

    foreach ($fields as $field) {
        if (isset($_POST[$field])) {
            $set .= "`$field` = ?,";
            $values[] = $_POST[$field];
        }
    }

    return rtrim($set, ',');
}
Nach dem Login kopieren

Beispielverwendung:

$fields = explode(" ","name surname lastname address zip fax phone date");
$_POST['date'] = $_POST['y']."-".$_POST['m']."-"$_POST['d'];

$query  = "UPDATE $table SET ".dbSet($fields, $values).", stamp=NOW() WHERE>
Nach dem Login kopieren

Vorteile von PDO vorbereitet Anweisungen:

  • Sicherheit: Verhindert SQL-Injection durch die Verwendung von Platzhaltern.
  • Effizienz: Bereitet die Abfrage einmal vor, reduziert die Datenbank Overhead.
  • Konsistenz: Sorgt für konsistente Daten Formatierung und Typkonvertierung.

Alternative Lösung: Object-Relational Mapping (ORM)

Erwägen Sie die Verwendung eines ORM wie Doctrine ORM, das die Datenpopulation und vereinfacht macht die manuelle Abfrageerstellung überflüssig.

$table = new Table();
$table->fromArray($_POST);
$table->save();
Nach dem Login kopieren

Dieser Ansatz automatisiert den Prozess der Zuordnung von Eigenschaften zur Datenbank Felder basierend auf definierten Entitätsklassen.

Das obige ist der detaillierte Inhalt vonWie kann ich meine MySQL-Einfüge-/Aktualisierungsfunktion mithilfe von PDO-vorbereiteten Anweisungen verbessern?. 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