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 :

Utiliser implode dans une requête [MySQL]


Sujet :

PHP & Base de données

  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Décembre 2007
    Messages
    178
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2007
    Messages : 178
    Par défaut Utiliser implode dans une requête
    Bonjour , je n'arrive pas à insérer des valeurs dans le même champs avec implode

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    $array = array($data['FAM_LIB'],$box_values[1]);		   
               $choix = implode("-->", $array);		   	
               $sqll = 'INSERT INTO testchoix VALUES("", "'.$choix.'")';
              mysql_query($sqll) or die('Erreur SQL !'.$sqll.'<br />'.mysql_error());
    Dans la table les choix s'incrémente et entre dans un nouveau champ

  2. #2
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Par défaut
    commence par faire un print_r($array) pour controler ce que tu as reellement puis un echo $sqll; pour voir ta requete finale.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Décembre 2007
    Messages
    178
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2007
    Messages : 178
    Par défaut
    Ok quand je coche 3 case je fais un print_r (array) et echo $sqll j'ai ceci

    Array ( [0] => Electricité [1] => installation )
    INSERT INTO testchoix VALUES("", "Electricité-->installation")
    Array ( [0] => Electricité [1] => rénovation )
    INSERT INTO testchoix VALUES("", "Electricité-->rénovation")
    Array ( [0] => Electricité [1] => chauffage/climat )
    INSERT INTO testchoix VALUES("", "Electricité-->chauffage/climat")

  4. #4
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Par défaut
    Et qu'est ce que tu souhaiterais toi ?
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  5. #5
    Membre confirmé
    Profil pro
    Inscrit en
    Décembre 2007
    Messages
    178
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2007
    Messages : 178
    Par défaut
    ben quu'il soit inséré dans le même champs dans la base de donnée

  6. #6
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Par défaut
    C'est quoi "il" ?
    Tu voudrais
    INSERT INTO testchoix VALUES("", "Electricité-->installationElectricité-->rénovationElectricité-->chauffage/climat")
    ??
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  7. #7
    Membre confirmé
    Profil pro
    Inscrit en
    Décembre 2007
    Messages
    178
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2007
    Messages : 178
    Par défaut
    oui voila c'est ça il se sont les resultats.
    La j'ai
    1.Electricité-->Rénovation
    2.Electricité-->installation

    moi je souhaite
    1.Electricité-->rénovation Electricité-->installation

  8. #8
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Par défaut
    C'est vraiment la chose la plus atroce que j'ai vu en base de donnée

    Mais si c'est vraiment ce que tu veux, il faut que tu fasses ta boucle sur la construction de $array mais qu'elle ne contienne pas l'insert.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  9. #9
    Membre confirmé
    Profil pro
    Inscrit en
    Décembre 2007
    Messages
    178
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2007
    Messages : 178
    Par défaut
    j'ai pas le choix je peu pas inserer pour 1 formulaire si la personnes choisi 10 champs utiliser 10 champs dans ma base de donnée pour 1 formulaire je pense que la ça deviendré atroce

  10. #10
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Par défaut
    C'est plus rassembler plusieurs données dans une seule colonne qui est atroce.
    Imagine les difficultés que tu auras pour analyser les données.
    Déjà tu alourdis considerablement ta base en repetant l'intégralité des données.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    utiliser 10 champs dans ma base de donnée
    Dans une base donnée, les données doivent s'enregistrer verticalement par en créant des colonnes.

    Une structure bien faite serait

    une table pour la premiere catégorie
    t_categorie
    id - nom
    ---
    1 - Electricité

    une table pour l'intervention
    id - nom - id_categorie
    ---
    1 - Installation - 1
    2 - Rénovation - 1

    et donc ta table enregistrant le formulaire
    id - utilisateur - intervention_id
    1 - 197489 - 1
    1 - 197489 - 2

    Tu vois en enregistrant uniquement 2, je sais que je parle de "Electricité-Rénovation".

    Je veux savoir ce qu'a coché mon utilisateur 197489 ?
    SELECT intervention_id FROM table WHERE utilisateur = 197489

    Et j'obtiens la liste, et pas une texte que serait obligé d'analyser et decouper.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  11. #11
    Membre confirmé
    Profil pro
    Inscrit en
    Décembre 2007
    Messages
    178
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2007
    Messages : 178
    Par défaut
    merci grace a ton exemple j'ai pu revoir toute ma structure et c'est vrai que même logiquement ça fonctionne mieu dans ma petite tête je te remercie maintenant je peut faire ce que je veu

    Et si je suis ta logique dans la table formulaire je dois récupérer 2 variables ?
    id de categorie et id de la intervention ?

  12. #12
    Modérateur
    Avatar de sabotage
    Homme Profil pro
    Inscrit en
    Juillet 2005
    Messages
    29 208
    Détails du profil
    Informations personnelles :
    Sexe : Homme

    Informations forums :
    Inscription : Juillet 2005
    Messages : 29 208
    Par défaut
    Dans mon exemple les interventions sont liées a des categories.
    Dans ce cas, avec l'id d'intervention tu connais la catégorie a laquelle elle appartient.

    Tu pourrais aussi avoir d'un côté les catégories et de l'autre les interventions avec possibilité de n'importe quelle combinaison.
    Dans ce cas il faut enregistrer la catégorie et l'intervention.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  13. #13
    Membre confirmé
    Profil pro
    Inscrit en
    Décembre 2007
    Messages
    178
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2007
    Messages : 178
    Par défaut
    Moi en faite tu me dis ce que tu en pense oui j'ai compris qu'il été liée
    j'enregistre dans la base ainsi en donnant a la valeur de la case $data['id'] et $data['sous_categorie_id']
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
       $valeur=$_POST['choix'];
       foreach($valeur as $choix)
       {
               $categorie = explode('_', $choix);
               $categorie_id = $categorie[0];
               $sous_categorie_id = $categorie[1];
     
              $sql=' INSERT INTO sujet_categorie VALUES ("'.$categorie[0].'", "'.$_SESSION['pseudo'].'","'.$categorie[1].'")';
             mysql_query($sql) or die('Erreur SQL !'.$sql.'<br />'.mysql_error());
        }

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

Discussions similaires

  1. [AC-2010] Est-il possible d'utiliser rechdom dans une requête
    Par tgodefroid dans le forum Requêtes et SQL.
    Réponses: 7
    Dernier message: 04/04/2013, 22h14
  2. utilisation de la fonction Partdate() dans une requête
    Par jm6570 dans le forum Requêtes et SQL.
    Réponses: 3
    Dernier message: 01/02/2010, 11h55
  3. Utilisation EXISTS dans une requête
    Par david666 dans le forum Requêtes
    Réponses: 5
    Dernier message: 06/08/2009, 14h47
  4. [FREETEXT][Sql2000] Utilisation dans une requête ?
    Par SoaB dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 18/10/2005, 14h49
  5. Utilisation de MAX dans une requête SQL
    Par Evil onE dans le forum Langage SQL
    Réponses: 7
    Dernier message: 15/06/2004, 18h38

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