Heim > Datenbank > MySQL-Tutorial > Hauptteil

Warum fügt mein PHP-Code nach nur einer Ausführung zweimal Daten in MySQL ein?

Susan Sarandon
Freigeben: 2024-11-10 04:11:02
Original
249 Leute haben es durchsucht

Why Does My PHP Code Insert Data Twice in MySQL After Only One Run?

Zweimal ist einmal: Probleme beim Einfügen in MySQL-Datenbanken verstehen

In einem verwirrenden Szenario wollte ein PHP-Code unerwartet Daten in eine MySQL-Datenbank einfügen fügt die Daten nach nur einem Lauf zweimal ein. Der Code funktioniert auf localhost einwandfrei, das Problem der Duplizierung tritt jedoch auf, wenn er auf einem Server bereitgestellt wird. Wenn die Seite außerdem zweimal aktualisiert wird, zeigt die Datenbank nur ein einziges Ergebnis an. Dieses verwirrende Dilemma wirft die Frage auf, welche Faktoren zu diesem abnormalen Verhalten beitragen.

Der versteckte Übeltäter

Die Antwort liegt in der Anfrageverarbeitung des Browsers. Wenn Browser eine Webseite laden, senden sie mehrere Anfragen, darunter eine für das Hauptskript und eine für das Favicon. Auch wenn der Code in diesem Fall nur einmal ausgeführt wird, leitet das Vorhandensein der .htaccess-Datei alle Anforderungen an die Indexdatei um, was zu mehreren Datenbankeinfügungen führt.

Die Lösung

Um dieses Problem zu beheben, sollte der Code so geändert werden, dass die Einfügungsabfrage nur für eine bestimmte Anfrage ausgeführt wird, mit Ausnahme der Favicon-Anfrage. Dies kann erreicht werden, indem eine Bedingung hinzugefügt wird, die prüft, ob die Datei favicon.ico im Anforderungs-URI vorhanden ist. Wenn die Datei nicht vorhanden ist, was auf eine reguläre Seitenanforderung hinweist, wird die Einfügeabfrage ausgeführt. andernfalls wird es übersprungen.

Überarbeiteter Code

Der folgende überarbeitete Code behebt das Problem, indem er die notwendige Bedingung einführt:

if (!strpos($_SERVER['REQUEST_URI'], 'favicon.ico')) {
    $result = mysql_query($sql);
}
Nach dem Login kopieren

Das obige ist der detaillierte Inhalt vonWarum fügt mein PHP-Code nach nur einer Ausführung zweimal Daten in MySQL ein?. 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