IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

PHP & Base de données Discussion :

php vers base mysql [MySQL]


Sujet :

PHP & Base de données

  1. #1
    Futur Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Septembre 2021
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Loiret (Centre)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Septembre 2021
    Messages : 4
    Par défaut php vers base mysql
    Bonjour,

    à l'aide de divers sites (je suis débutant), j'ai crée ce fichier php

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
     
     
    <?php
    // On commence par récupérer les champs
    if(isset($_POST['birth']))      $nom=$_POST['birth'];
    else      $birth="";
     
    if(isset($_POST['country']))      $prenom=$_POST['country'];
    else      $country="";
     
        {
           // connexion à la base
    $db = mysql_connect('server', 'nom de la base', 'mot de passe')  or die('Erreur de connexion '.mysql_error());
    // sélection de la base  
     
        mysql_select_db('grubblfgrubblle',$db)  or die('Erreur de selection '.mysql_error());
     
        // on écrit la requête sql
        $sql = "INSERT INTO birthdates(birth,country) VALUES('','$birth','$country')";
     
        // on insère les informations du formulaire dans la table
        mysql_query($sql) or die('Erreur SQL !'.$sql.'<br>'.mysql_error());
     
        // on affiche le résultat pour le visiteur
        echo 'Vos infos ont été ajoutées.';
     
        mysql_close();  // on ferme la connexion
        } 
    ?>
    c'est pour envoyer les données (birth=date de naissance / country=pays d'origine) d'un formulaire vers une base mysql. Malheureusement quand je valide le formulaire renseigné je me trouve avec un écran blanc et la table concernée ("birthdates") dans la base n'est pas alimentée.

    Est-ce que quelqu'un aurait une idée de pourquoi ?

    merci par avance pour toute suggestion :-)

    cordialement

  2. #2
    Membre confirmé
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2015
    Messages
    84
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 30
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Janvier 2015
    Messages : 84
    Par défaut
    Salut,

    Rien ne t’empêche de mettre des écho dans ton code php pour savoir si il bloque à un certain point,

    quand on débute c'est très utile pour mieux comprendre ce que l'on peut faire ou non dans sa requête php.

    Au lieu de piquer sur 20 sites différents, tu peux déjà tester une requête simple pour voir si tout fonctionne correctement, et dans ton moteur de recherche préféré en tapant "insert php mysql" tu ne devrais pas chercher dans plus d'un où deux sites avant de trouver un exemple parfait de connexion à ta base de données

  3. #3
    Futur Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Septembre 2021
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Loiret (Centre)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Septembre 2021
    Messages : 4
    Par défaut merci
    merci beaucoup pour ces conseils :-)

  4. #4
    Expert confirmé
    Avatar de Séb.
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    5 315
    Détails du profil
    Informations personnelles :
    Âge : 47
    Localisation : France

    Informations professionnelles :
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 315
    Billets dans le blog
    17
    Par défaut
    Je te conseille d'éviter les sites qui conseillent encore les fonctions mysql_*()
    Elles sont obsolètes depuis des années et supprimées à partir de PHP 7
    Tu tournes sous quelle version de PHP ?

    Utilise plutôt PDO => https://php.net/pdo


    Il y a un truc bizarre ici :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    if(isset($_POST['birth']))      $nom=$_POST['birth'];
    else      $birth="";
    Indente/aère ton script, on voit mieux la bizarrerie :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    if (isset($_POST['birth'])) {
        $nom = $_POST['birth'];
    } else {
        $birth = "";
    }
    Pourquoi $nom et pas $birth ?

    Fais plutôt :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    if (isset($_POST['birth'])) {
        $birth = $_POST['birth'];
    } else {
        $birth = "";
    }
    Que l'on peut abréger en :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $birth = isset($_POST['birth']) ? $_POST['birth'] : '';
    Ou sur un PHP non antédiluvien ;

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $birth = $_POST['birth'] ?? '';
    Ensuite ton SQL :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $sql = "INSERT INTO birthdates(birth,country) VALUES('','$birth','$country')";
    Tu listes 2 colonnes mais le VALUES en donne 3, il faudrait plutôt faire :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $sql = "INSERT INTO birthdates(birth,country) VALUES('$birth','$country')";
    Ou d'une pierre deux coups sur un PHP non antédiluvien :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    $sql = <<<SQL
        INSERT INTO birthdates
        SET birth = '$birth', country = '$country'
        SQL;
    Avec cette syntaxe INSERT MySQL on évite ce genre d'erreurs.

  5. #5
    Futur Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Septembre 2021
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Loiret (Centre)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Septembre 2021
    Messages : 4
    Par défaut merci pour la réponse pédagogique
    bonjour et mille merci

    oui je ne voyais pas ces incohérences, ma méthode n'est pas encore structurée, vous avez raison

    j'entame une formation mais, trop curieux, j'ai voulu tenter cet essai avant ! je vais peut être attendre un peu ;-)

    - que veut dire antediluvien ?
    - où connait-on sa version de PHP ?

    encore merci, bonne journée

  6. #6
    Expert confirmé
    Avatar de Séb.
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    5 315
    Détails du profil
    Informations personnelles :
    Âge : 47
    Localisation : France

    Informations professionnelles :
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 315
    Billets dans le blog
    17
    Par défaut
    Citation Envoyé par grubblle Voir le message
    - que veut dire antediluvien ?
    D'avant le déluge, d'un âge biblique

    - où connait-on sa version de PHP ?
    Fais phpinfo() ou phpversion()

  7. #7
    Membre Expert
    Avatar de laurentSc
    Homme Profil pro
    Webmaster débutant perpétuel !
    Inscrit en
    Octobre 2006
    Messages
    10 486
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster débutant perpétuel !
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 486
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par grubblle Voir le message
    - que veut dire antediluvien ?
    Ce que veut dire Séb., c'est qu'il s'agit d'une nouvelle syntaxe, disponible depuis PHP7 : $a = $b ?? ''; revient au même depuis PHP7 que $a = (isset($b)) ? $b : ''; // opérateur ternaire qui revient lui-même au même que
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    if (isset($b)) {
        $a = $b;
    }
    else {
        $a = '';
    }
    De même, il te propose une syntaxe plus claire pour faire un INSERT sous MySQL.

    Citation Envoyé par grubblle Voir le message
    - où connait-on sa version de PHP ?
    https://www.php.net/manual/fr/function.phpversion.php

    Tout à fait d'accord pour passer à PDO : https://www.developpez.net/forums/bl...pdo-soupe-lit/

  8. #8
    Futur Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Septembre 2021
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Loiret (Centre)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Septembre 2021
    Messages : 4
    Par défaut merci à vous deux !
    bonne journée

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réplication données depuis Base SQL Server vers Base MYSQL
    Par elspliffo dans le forum Réplications
    Réponses: 2
    Dernier message: 27/09/2007, 14h02
  2. Base de données Access 2007 vers base MySQL ?
    Par Lili72430 dans le forum Access
    Réponses: 3
    Dernier message: 20/09/2007, 14h41
  3. exporter contenu d'un fichier excel vers base mysql ?
    Par ouldfella dans le forum Requêtes
    Réponses: 5
    Dernier message: 08/03/2007, 10h31
  4. connexion depuis site internet vers base mysql distante
    Par Carter dans le forum SQL Procédural
    Réponses: 3
    Dernier message: 19/09/2006, 13h24
  5. [MySQL] Filtre via formulaire HTML/PHP dans Base mySQL
    Par Al3x dans le forum PHP & Base de données
    Réponses: 1
    Dernier message: 14/01/2006, 16h27

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo