Maison > base de données > tutoriel mysql > Pourquoi ai-je deux entrées dans ma base de données MySQL alors que je n'insère qu'une seule fois en PHP ?

Pourquoi ai-je deux entrées dans ma base de données MySQL alors que je n'insère qu'une seule fois en PHP ?

DDD
Libérer: 2024-12-03 01:49:10
original
912 Les gens l'ont consulté

Why Do I Get Two Entries in My MySQL Database When I Only Insert Once in PHP?

Pourquoi l'insertion une fois dans PHP provoque-t-elle deux entrées dans la base de données MySQL ?

Lors de l'exécution du code PHP fourni sur un serveur, vous pouvez rencontrer un problème déroutant où l'insertion d'un seul enregistrement dans une base de données MySQL entraîne deux entrées. Ce problème, qui se manifeste lorsque le code est déployé sur un serveur live mais pas sur localhost, a dérouté les développeurs.

Le coupable derrière cette anomalie réside dans le comportement du navigateur. Lors de l'actualisation de la page, le navigateur envoie deux requêtes au serveur : une pour le script principal et une autre pour le favicon. Dans cette situation, la requête d'insertion est exécutée deux fois, conduisant à l'insertion de deux enregistrements.

Pour résoudre ce problème, la requête d'insertion doit être limitée à une seule des requêtes. En implémentant une vérification conditionnelle qui vérifie si la requête concerne le script principal, vous pouvez empêcher l'exécution de la requête pour la requête favicon.

Voici un extrait de code modifié qui résout ce problème :

<?php
$db = mysql_connect('localhost', 'zzzzzzz', 'xxxxxx') or die('Unable to connect.' . mysql_error());
mysql_select_db('test', $db) or die(mysql_error($db));

// Check if the request is for the main script
if ($_SERVER['REQUEST_URI'] == '/script.php') {
    $sql = "INSERT INTO test_table(value, insert_time) VALUES ('testing', '" . time() . "')";
    $result = mysql_query($sql);
}

$select = "select * from test_table";
$rs = mysql_query($select);
while ($row = mysql_fetch_array($rs)) {
    echo $row["test_id"] . " -- " . $row["value"] . " -- " . $row["insert_time"] . "<br />";
}
?>
Copier après la connexion

En incorporant cette vérification conditionnelle, la requête d'insertion n'est exécutée que lorsque le script principal est demandé, garantissant qu'un seul enregistrement est inséré dans la base de données.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal