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

Langage PHP Discussion :

PHP insertion multiple


Sujet :

Langage PHP

  1. #1
    Membre du Club
    Inscrit en
    Février 2010
    Messages
    103
    Détails du profil
    Informations forums :
    Inscription : Février 2010
    Messages : 103
    Points : 44
    Points
    44
    Par défaut PHP insertion multiple
    Bonsoir à tous,

    Voilà quelques années que je n'ai pas développer. Dure de s'y remettre ...!

    Bon cela fait trois jours que je m'arrache les cheveux alors je rentre de suite dans le vif du sujet.


    J'ai une page qui affiche des images provenant d'un dossier stocké sur le serveur.
    Je les affiche et celles-ci sont sélectionnables indépendamment avec une Checbox -> OK
    Lorsque celles-ci sont sélectionne, elles s'ajoutent automatiquement en miniature dans un formulaire -> OK

    Dans ce formulaire je récupère via des inputs le nom du visiteur et le nom de l'album. Je souhaite donc à la validation du formulaire enregistré dans ma BDD plusieurs lignes (Sachant que je ne connais pas par avance le nombre d'image qui seront sélectionnés) du type :

    - NOM - ALBUM - IMG1
    - NOM - ALBUM - IMG2
    - NOM - ALBUM - IMG3
    - (...)

    Je bute donc sur cette boucle qui me permettra de récupérer les données de mon formulaires pour les traduire en enregistrements multiples dans ma BDD.

    Mon formulaire :

    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
    <form name="albclient" action="album_client_et2.php" method="post">
    <input type="text" value ="<?php print uniqid();?>" name="identifiantv" id="identifiantv">
    <input type="text" id="<?php print $album;?>" name="<?php print $album;?>" value="<?php print $album;?>">
     
    <?php 
     
    if(!empty($fichier)){
        sort($fichier);// pour le tri croissant, rsort() pour le tri décroissant
     
      foreach($fichier as $lien) {
    $file_name = $lien;
    $file_array = explode ('.',$file_name);
    $extension = count ($file_array) - 1;
    $visu = substr ($file_name,0,strlen($file_name) -strlen ($file_array[$extension])-1);
    $imgvisu = $visu;
     
                echo "\t\t\t    
    <div class =\"$visu-class\" id=\"visu$visu\" style=\"display:inline-block\">
    <a><img src=\"$dir_nom/$lien \" class=\"minifolio\"><input type=\"text\" id=\"numerovisu\" name=\"numerovisu\" value=\"$imgvisu\"></a>
     </div>
    \n";  
            }
     
        }
     
    ?>
     
    	 <input type="submit" name="newvisit" id="newvisit"  value="Continuer"  class="flatbtn-blu hidemodal" style="float:right; margin:30px"/>
    	</form>
    Et voici la page contenant le traitement :

    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
    30
    31
    32
     
     
    <?php
     
     
    // lancement de la requete
     
    if (isset($_POST['newvisit']) && $_POST['newvisit'] == 'Continuer') {
     
    /* $id = mysql_insert_id(); */
     
    $imgvisu=$_POST['numerovisu'];
    $identifiantv = $_POST['identifiantv']; 
    $idalbum = $_POST['idalbum']; 
     
    	/* while ($row_imgvisu = array_shift($imgvisu))
    	    {  */
    	$sql = "INSERT INTO bd_visiteur (id, idvisiteur, idalbum, idimage, format1, format2, format3, format4, quantite1, quantite2, quantite3, quantite4) VALUES ('$id', '$identifiantv', '$idalbum', '$row_imgvisu', '', '', '', '', '', '', '', '')";
    	$result = mysql_query ($sql);
        /* }  */
     
     
    if (mysql_query ($sql)) {
    		    echo "Nouveau(x) enregistrement(s) : ".$imgvisu."<br>".$idalbum."<br>";
    } else {
    		    echo "Erreur SQL ! ".$sql."<br>".mysql_error();
    		}
     
    	}
    mysql_close();
     
    ?>

    A noter : echo "Nouveau(x) enregistrement(s) : ".$imgvisu."<br>".$idalbum."<br>"; -> Me renvoie le nombre d'image contenu dans mon dossier au lieu de me lister les images sélectionné avec leur valeur...

    J’espère être clair, j'ai plus de cheveux...
    Quelqu'un saurait-il m'aiguiller ?

    Cordialement,
    Ruddy

  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
    Points : 44 155
    Points
    44 155
    Par défaut
    Je ne vois pas de checkbox dans le code que tu nous montres.
    Quelque chose comme :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <input type="checkbox" name="numerovisu[]" value="$imgvisu">
    Et a l'arrivée tu parcoures les résultats cochés :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    foreach ($_POST['numerovisu'] as $imgvisu) {
    A noter que tu as mis un $id dans ta requête qui n'est pas défini.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  3. #3
    Membre du Club
    Inscrit en
    Février 2010
    Messages
    103
    Détails du profil
    Informations forums :
    Inscription : Février 2010
    Messages : 103
    Points : 44
    Points
    44
    Par défaut
    Merci Sabotage,
    Pour le coup ce n’était peut-être pas très clair, je reposte toute ma page (Enfin juste la section) avec les Checkbox défini au préalable.

    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
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
     
     
    <section>
     
    <!-- ************************************************************** -->
    <!--Afficheur d'images -  On affiche le nombre d'images présent dans le dossier -->
    <?php
    $dir_nom = "img/album_clients/album_$album/."; // dossier listé (pour lister le répertoir courant : $dir_nom = '.'  --> ('point')
    $dir = opendir($dir_nom) or die('Erreur de listage : le répertoire n\'existe pas'); // on ouvre le contenu du dossier courant
    $fichier= array(); // on déclare le tableau contenant le nom des fichiers
     
     
    while($element = readdir($dir)) {
        if($element != '.' && $element != '..') {
            if (!is_dir($dir_nom.'/'.$element)) {$fichier[] = $element;}
            else {$dossier[] = $element;}
        }
    }
    closedir($dir);
    if(!empty($fichier)){
        sort($fichier);// pour le tri croissant, rsort() pour le tri décroissant
        echo "\t\t <div class=\"Collage effect-parent\" id=\"cochephotos\" style=\"width:75%; float:left\">\n";
     
     
     
            foreach($fichier as $lien) {
     
    // Je met le nom de mon fichier dans une variable
    $file_name = $lien;
    // J'explose dans un tableau à chaque fois que je rencontre un point
    $file_array = explode ('.',$file_name);
    // Je récupère l'indice dans le tableau de l'extension "jpg", soit le dernier élément
    $extension = count ($file_array) - 1;
    // Je découpe en enlevant l'extension cad (la taille de "jpg" + la taille du point d'où le -1)
    $numero = substr ($file_name,0,strlen($file_name) -strlen ($file_array[$extension])-1);
    // J'affiche
    //echo $numero; 
     
                echo "\t\t\t    
    <div class=\"Image_Wrapper\" data-caption=\"$numero\"><div class =\"checkdiv\"><input name=\"chk$numero\" id=\"chk$numero\" value=\"$numero\" class=\"check\" type=\"checkbox\" checked=\"checked\" /></div>
    <a><img src=\"$dir_nom/$lien \"></a>
     </div>
    \n";  
            }
     
        echo "\t\t </div>\n";
     }
    ?>
     
    <div id="recap">
     
     
    	<div class="bgrecap"> <h1> Etape 1</h1> <span style="color:#222"> Sélectionner vos photos</span> </div>
     
    	<div class="bgrecap">
    	<!-- ************************************************************** -->
    	<!--Compteur d'images -  On compte le nombre d'images présent dans le dossier -->
    	<?php
    		$files = glob("img/album_clients/album_$album/*.*");/* $files pour "lister" les fichiers - Mise en place de *.* pour dire que ce dossier contient une extension (par exemple .jpg, .php, etc... */
    		$compteur = count($files);/* Variable $compteur pour compter (count) les fichiers lister ($files) dans le dossier */
    		echo "Il y a <font color=#960018>$compteur</font>";
    		if ($compteur > 1) { echo " photos dans cet album"; }
    		else { echo " photo dans cet album"; }
    	?>
    	<!--Fin Compteur d'images -->
    	<br>
    	<span>Tout cocher/ décocher </span><input id="checkAll" class="all" type="checkbox" checked/>
     
    	</div>
     
    	<div class="bgrecap">
     
    	<form name="albclient" action="album_client_et2.php" method="post">
    <input type="text" value ="<?php print uniqid();?>" name="identifiantv" id="identifiantv">
    <input type="text" id="<?php print $album;?>" name="<?php print $album;?>" value="<?php print $album;?>">
     
    <?php 
     
    if(!empty($fichier)){
        sort($fichier);// pour le tri croissant, rsort() pour le tri décroissant
     
      foreach($fichier as $lien) {
    $file_name = $lien;
    $file_array = explode ('.',$file_name);
    $extension = count ($file_array) - 1;
    $visu = substr ($file_name,0,strlen($file_name) -strlen ($file_array[$extension])-1);
    $imgvisu = $visu;
     
                echo "\t\t\t    
    <div class =\"$visu-class\" id=\"visu$visu\" style=\"display:inline-block\">
    <a><img src=\"$dir_nom/$lien \" class=\"minifolio\"><input type=\"text\" id=\"numerovisu\" name=\"numerovisu\" value=\"$imgvisu\"></a>
     </div>
    \n";  
            }
     
        }
     
    ?>
     
     
    	 <input type="submit" name="newvisit" id="newvisit"  value="Continuer"  class="flatbtn-blu hidemodal" style="float:right; margin:30px"/>
    	</form>
    	</div>
     
     
     
    </div>
          <div class="clear"></div>
     
    </section>
    Je n'ai pas de souci pour donner attribuer l'identifiant à mon image dans un input de mon formulaire, ce après le clic sur le checkbox.
    C'est lorsque je traite le formulaire que je n'arrive pas à lister et enregistrer dans ma BD les image sélectionner.

    Du type :

    - NOM - ALBUM - IMG 1
    - NOM - ALBUM - IMG 2
    - NOM - ALBUM - IMG 3
    - ...


    Comprends tu mon problème ?

  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
    Points : 44 155
    Points
    44 155
    Par défaut
    Tu as regardé mon exemple ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    foreach ($_POST['chk'] as $numero) {
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  5. #5
    Membre du Club
    Inscrit en
    Février 2010
    Messages
    103
    Détails du profil
    Informations forums :
    Inscription : Février 2010
    Messages : 103
    Points : 44
    Points
    44
    Par défaut
    J'ai bien testé ta réponse mais celle-ci ne me renvoie pas non plus le résultat escompté.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
     
    <?php
    $_POST['chk'] = array_keys($_POST);
     
    foreach ($_POST['chk'] as $numero) 
    {
        echo $numero; echo '<br />';
    }
    ?>
    Me renvoie une ligne composé des identifiants des inputs :

    identifiantv
    test
    chk
    newvisit

    Et non une boucle sur les images et leurs valeurs.


    Je sèche un peu, je pense que je réfléchis mal alors que le problème est tout simple.

  6. #6
    Membre du Club
    Inscrit en
    Février 2010
    Messages
    103
    Détails du profil
    Informations forums :
    Inscription : Février 2010
    Messages : 103
    Points : 44
    Points
    44
    Par défaut
    Pour mieux visualiser voici une capture de ma page :
    Nom : Capture du 2016-03-09 22:42:51.png
Affichages : 102
Taille : 972,8 Ko

    A gauche, les images de mon dossier. Adroite mon formulaire qui affiche dans le premier input l'ID unique de mon visiteur, suivi du nom de l'album et enfin les images séléctionnés (Ici la 04 et la 07).
    Le problème est maintenant à l'étape suivante d'enregistrer les images choisi par le visiteur dans la base sous la forme multiple suivante :

    id identifiantv idalbum idimage
    1 56e098bdd2025 test 04
    2 56e098bdd2025 test 07

    Enfin j’espère que c'est plus clair dans mes explications comme cela ?!

  7. #7
    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
    Points : 44 155
    Points
    44 155
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $_POST['chk'] = array_keys($_POST);
    Pourquoi cette ligne ?
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  8. #8
    Membre du Club
    Inscrit en
    Février 2010
    Messages
    103
    Détails du profil
    Informations forums :
    Inscription : Février 2010
    Messages : 103
    Points : 44
    Points
    44
    Par défaut
    Bonne question.
    Je mélange tout et je m'y perds...
    j'ai retiré cette ligne; Celà me renvoie bien les numéros mais le problème c'est qu'il ne s'agit pas uniquement de ceux que j'ai sélectionné mais de toutes les images contenus dans le dossier... (En l'occurence ici 11...)

  9. #9
    Membre du Club
    Inscrit en
    Février 2010
    Messages
    103
    Détails du profil
    Informations forums :
    Inscription : Février 2010
    Messages : 103
    Points : 44
    Points
    44
    Par défaut
    Alors je viens de capter une partie du problème.
    Une fois les images cochés, les divs de mon formulaire passent en visible. Laissant les images non cochés en Hide dans mon formulaire.
    Le problème est que lors du traitement du formulaire, les Hide sont également affichés.

    D'ou ma problèmatique maintenant afficher uniquement les resultats des images sélectionnés dont les div sont en visible ?!

    Pour exemple, je sélectionne l'image 04 et 07 mais le traitement m'affiche également les Hides, donc :
    01
    02
    03
    04
    05
    06
    07
    08
    09
    10
    11

  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
    Points : 44 155
    Points
    44 155
    Par défaut
    Ca devient une question de Javascript la, plus de PHP.
    N'oubliez pas de consulter les FAQ PHP et les cours et tutoriels PHP

  11. #11
    Membre du Club
    Inscrit en
    Février 2010
    Messages
    103
    Détails du profil
    Informations forums :
    Inscription : Février 2010
    Messages : 103
    Points : 44
    Points
    44
    Par défaut
    Pour le coup, je me suis planté dès le départ en n'incluant pas les checkboxs dans mon formulaire.
    Maintenant j'arrive bien à afficher uniquement les numéros d'images que j'ai coché !

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    <?php
     
    foreach ($_POST['chk'] as $value) 
    {
        echo $value; echo '<br />';
    }
    ?>
    Seulement je souhaite également récupéré la valeur "identifiantv" et "idalbum".
    Comment puis je l'inclure en résultat dans la boucle foreach avec "chk" ?

Discussions similaires

  1. [MySQL] Php Insert multiple final
    Par lola08250 dans le forum PHP & Base de données
    Réponses: 9
    Dernier message: 05/11/2014, 16h29
  2. Réponses: 1
    Dernier message: 25/01/2010, 23h06
  3. Insertion multiples via script php
    Par furtif1 dans le forum SQL Procédural
    Réponses: 3
    Dernier message: 09/04/2007, 17h03
  4. INSERT multiples avec : rs.AddNew et .Update
    Par M.Zip dans le forum ASP
    Réponses: 4
    Dernier message: 03/12/2004, 15h53
  5. pb d'insertions multiples
    Par devalender dans le forum SQL
    Réponses: 2
    Dernier message: 14/07/2004, 14h49

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