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

Outils MySQL Discussion :

Insert qui ne fonctionne pas


Sujet :

Outils MySQL

  1. #1
    Futur Membre du Club
    Inscrit en
    Octobre 2005
    Messages
    8
    Détails du profil
    Informations forums :
    Inscription : Octobre 2005
    Messages : 8
    Points : 6
    Points
    6
    Par défaut Insert qui ne fonctionne pas
    Bonjour,

    Je debute en php et my sql et j'ai voulu me créer une tite base de données histoire d'apprendre un peu comment ca se passe.
    J'ai donc créé une base Mysql qui s'appelle test-1 avec une table qui s'appelle table-1 et qui contient 2 champs : nom et fonction.

    Mais je n'arrive pas a faire mon insert dans ma table...voici le le bout de code correspondant :
    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
     
    <html>
    <head>
    <title>Ma page de traitement</title>
    </head>
    <body>
    <?php
                 // on teste la déclaration de nos variables
    if (isset($_POST['nom']) && isset($_POST['fonction']))
    {
    echo 'Votre nom est '.$_POST['nom'].' et votre fonction est '.$_POST['fonction'];
    echo "INSERT INTO table-test values('$nom','$fonction')";
                 // on se connecte  a la base de données
     $base = mysql_connect ('localhost', 'root', '')or die
      ("Impossible de se connecter à la base de données");   
     mysql_select_db ('test-1')or die ("Connexion à la base $base impossible");  
                 // on insere les champs dans la table
      $insert = "INSERT INTO table-test values('$nom','$fonction')";
     $query = mysql_query($insert) OR die("Impossible d’ajouter le message ! ");
                 // on ferme la connection à la base de données
     mysql_close();
    }
    ?>
    </body>
    </html>
    Ce qui me parait bizarre c'est que le echo de ma requete car ca me donne ca :

    INSERT INTO table-test values('','')Impossible d’ajouter le message !
    ..mais je ne comprends pas pourquoi .

    Merci pour votre aide

  2. #2
    Rédacteur
    Avatar de pcaboche
    Homme Profil pro
    Inscrit en
    Octobre 2005
    Messages
    2 785
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : Singapour

    Informations forums :
    Inscription : Octobre 2005
    Messages : 2 785
    Points : 9 716
    Points
    9 716
    Par défaut
    Je ne sais pas si tu peux mettre un '-' dans le nom d'une table, mais ça me semble bizarre.

    Si tu veux apprendre à manipuler MySQL, prend un outil comme phpMyAdmin dans lequel tu pourras tester tes requêtes en toute liberté.
    "On en a vu poser les armes avant de se tirer une balle dans le pied..."
    -- pydévelop

    Derniers articles:

    (SQL Server) Introduction à la gestion des droits
    (UML) Souplesse et modularité grâce aux Design Patterns
    (UML) Le Pattern Etat
    Autres articles...

  3. #3
    Futur Membre du Club
    Inscrit en
    Octobre 2005
    Messages
    8
    Détails du profil
    Informations forums :
    Inscription : Octobre 2005
    Messages : 8
    Points : 6
    Points
    6
    Par défaut
    J'ai enlevé tous les "-" de mes noms de tables et de base mais je n'arrive toujours pas a faire mon insert... par contre j'ai change un peu mon code et ya du progres car dans le echo de ma requete on voit bien ce que j'ai saisi...
    mais a priori ca ne suffit pas

    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
     
    <html>
    <head>
    <title>Ma page de traitement</title>
    </head>
    <body>
    <?php
                 // on teste la déclaration de nos variables
    if (isset($_POST['nom']) && isset($_POST['fonction']))
    {
    echo 'Votre nom est '.$_POST['nom'].' et votre fonction est '.$_POST['fonction'];
     
                 // on se connecte  a la base de données
     $base = mysql_connect ('localhost', 'root', '')or die
      ("Impossible de se connecter à la base de données");   
     mysql_select_db ('test')or die ("Connexion à la base $base impossible");  
                 // on insere les champs dans la table
        echo 'INSERT INTO tabletest values("'.addslashes($_POST['nom']).'","'.addslashes($_POST['fonction']).'")';
      $insert = "INSERT INTO table-test values('$nom','$fonction')";
     $query = mysql_query($insert) OR die("Impossible d’ajouter le message ! ");
     
                 // on ferme la connection à la base de données
     mysql_close();
    }
    ?>
    </body>
    </html>
    maintenant le echo de ma requete donne ca :
    INSERT INTO tabletest values("xf","cx")Impossible d’ajouter le message !

  4. #4
    Membre émérite
    Avatar de yiannis
    Profil pro
    Inscrit en
    Septembre 2005
    Messages
    1 494
    Détails du profil
    Informations personnelles :
    Âge : 59
    Localisation : France

    Informations forums :
    Inscription : Septembre 2005
    Messages : 1 494
    Points : 2 791
    Points
    2 791
    Par défaut
    probleme php

    essaie comme cela:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    $insert = "INSERT INTO table-test values('".$_POST['nom']."','".$_POST['fonction']."')";
    "Ce besoin de remords qui précède le Mal, que dis-je ! qui le crée..." E. CIORAN

  5. #5
    Futur Membre du Club
    Inscrit en
    Octobre 2005
    Messages
    8
    Détails du profil
    Informations forums :
    Inscription : Octobre 2005
    Messages : 8
    Points : 6
    Points
    6
    Par défaut
    Merci Yiannis, ca marche maintenant mais... tu peux me dire pourquoi je dois coder comme ca ?
    Parce que j'ai lu plein d'exemples ou il n'y avait pas ce type de code..ca depend de quoi ? de la version php ?
    En tout cas encore merci

  6. #6
    Rédacteur
    Avatar de pcaboche
    Homme Profil pro
    Inscrit en
    Octobre 2005
    Messages
    2 785
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : Singapour

    Informations forums :
    Inscription : Octobre 2005
    Messages : 2 785
    Points : 9 716
    Points
    9 716
    Par défaut
    Autre chose: tu ne précises pas le nom de tes colonnes dans ta requête INSERT, ce qui suppose que ta table ne contient que 2 champs (nom et fonction). Si tu as d'autres champs pour lesquels tu n'as pas spécifié de valeur par défaut (comme par exemple un identifiant en AUTO_INCREMENT), c'est foutu !

    Aussi, la fonction mysql_error() renvoie un message d'erreur beaucoup plus précis:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ... or die( mysql_error() ) ;
    "On en a vu poser les armes avant de se tirer une balle dans le pied..."
    -- pydévelop

    Derniers articles:

    (SQL Server) Introduction à la gestion des droits
    (UML) Souplesse et modularité grâce aux Design Patterns
    (UML) Le Pattern Etat
    Autres articles...

  7. #7
    Futur Membre du Club
    Inscrit en
    Octobre 2005
    Messages
    8
    Détails du profil
    Informations forums :
    Inscription : Octobre 2005
    Messages : 8
    Points : 6
    Points
    6
    Par défaut
    ha oki il faut que je fasse un code de ce type alors :

    $insert = "INSERT INTO tabletest (nom,fonction)values('".$_POST['nom']."','".$_POST['fonction']."')";

    en admettant que nom et fonction soient les 2 colonnes de ma table . c'est ca ?

  8. #8
    Rédacteur
    Avatar de pcaboche
    Homme Profil pro
    Inscrit en
    Octobre 2005
    Messages
    2 785
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : Singapour

    Informations forums :
    Inscription : Octobre 2005
    Messages : 2 785
    Points : 9 716
    Points
    9 716
    Par défaut
    C'est ça !
    "On en a vu poser les armes avant de se tirer une balle dans le pied..."
    -- pydévelop

    Derniers articles:

    (SQL Server) Introduction à la gestion des droits
    (UML) Souplesse et modularité grâce aux Design Patterns
    (UML) Le Pattern Etat
    Autres articles...

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

Discussions similaires

  1. INSERT qui ne fonctionne pas
    Par KiranoO dans le forum Requêtes
    Réponses: 3
    Dernier message: 03/07/2008, 18h34
  2. Requête insert qui ne fonctionne pas .
    Par Pioul dans le forum VBA Access
    Réponses: 7
    Dernier message: 21/05/2008, 12h28
  3. Bulk Insert qui ne fonctionne pas
    Par genio dans le forum MS SQL Server
    Réponses: 8
    Dernier message: 01/11/2007, 01h13
  4. [MySQL] INSERT qui ne fonctionne pas
    Par djudjublondin dans le forum PHP & Base de données
    Réponses: 5
    Dernier message: 08/08/2007, 19h46
  5. [ODBC] une requete d'insertion qui ne fonctionne pas
    Par boulhous dans le forum PHP & Base de données
    Réponses: 2
    Dernier message: 26/05/2006, 13h56

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