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 :

Problème de select multiple + database


Sujet :

Langage PHP

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    93
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2006
    Messages : 93
    Points : 49
    Points
    49
    Par défaut Problème de select multiple + database
    Salut, j'utilise un formulaire de ce type
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    <select name=assign_type[] MULTIPLE>
    <option value=143 SELECTED>Administrateur de réseau</option>
    <option value=97 >Administrateur de système</option>
    <option value=32 >test3</option>
    </select>
    Voila, vous aurez remarqué que c'est une liste multiple et j'aimerais pouvoir enregistrer dans ma bd seulement ceux qui sont sélectionner après l'événement de submit. Autant ceux que je déselectionne que ceux que je selectionne.

    Bon je callère de plus d'un jour sur ce problème et je ne trouve pas comment.
    Jutilise un tableau et j'essaye de les comparer pour pouvoir faire ressortir celui qui est différent, mais après l'algo ne fonctionne pas pour celui que je déselectionne....


    mes champs dans ma tables sont ceci :
    • opportunities_titles
      • opportunity_title_id
      • opportunity_title_name
      • type_assign
      • opportunity_title_record_status




    Merci de bien vouloir m'aider,

  2. #2
    Membre expérimenté Avatar de julien.63
    Profil pro
    balayeur
    Inscrit en
    Décembre 2005
    Messages
    1 348
    Détails du profil
    Informations personnelles :
    Localisation : France, Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : balayeur

    Informations forums :
    Inscription : Décembre 2005
    Messages : 1 348
    Points : 1 311
    Points
    1 311
    Par défaut
    salut,
    je n'ai pas vraiment saisi où se situe ton problème.
    Quand tu soumets un select multiple, tu obtiens, dans $_POST un tableau au nom de ton select qui contient les valeurs sélectionnées.
    Teste le code suivant :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    <?php
    print_r($_POST);
    ?>
     
    <form action="" method="POST">
    <select name=assign_type[] MULTIPLE>
    <option value=143 SELECTED>Administrateur de réseau</option>
    <option value=97 >Administrateur de système</option>
    <option value=32 >test3</option>
    </select>
    <input type="submit">
    </form>

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    93
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2006
    Messages : 93
    Points : 49
    Points
    49
    Par défaut
    Salut effectivement l'énoncé du problème ne semble pas être bien fait.

    Voilà, je sais comment aller chercher mes valeurs de mon select, c'est lorsque je veux enregistrer mes modifications de selections dans mon select.

    Disons que par defaut j'ai deja 5 sélection de faite et que je veux en ajouter une, parfait, je n'ai qu'à l'ajouter dans ma table de relation, mais si j'en ajoute un et j'en enlève un autre, je dois être capable de comparer mes 2 tableaux, c-a-d celui de ma liste et celui generer par ma table de ma BD.

    Entre temps j'ai trouvé array_udiff qui est fabuleux grâce au callback, mais j'ai très vite remarquer qu'il était compatible seulement php5 et je ne peux me permettre dans mon environnement de travaille de le mettre à jours, j'ai la version 4.30 de php.

    Donc, depuis que je sais ca, je me suis créé mon propre algo et je crois que ca va fonctionner, je dit "je crois" car j'ai les mains plongé dedans et il me reste qu'a faire une verif d'un update... Ne vous gênez pas de critiquer mon code car j'ai bien besoin de m'amiliorer.

    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
     
    <?php
    [...]
    $type = $_POST['type_alias1'];
    $tab_lier = array();
     
    $tab_lier['opportunity_title'] = $_POST['assign_type'];
     
    $sql = "SELECT opportunity_title_id,opportunity_title_name,type_assign " .
    		"FROM opportunities_titles " .
    		"WHERE type_assign LIKE '".$type."' " .
    		"AND opportunity_title_record_status LIKE 'a'";
    $rst=$con->execute($sql);
     
    // Tableau
    $tab_bd = array();
    $tab_upd = array();
    $tab_id = array();
     
    $tab_id = $rst->GetArray();
    $tab_upd = $tab_lier['opportunity_title'];
     
    echo "<hr/>";
     
    for($i=0;$i<count($tab_id);$i++) {
    	$tab_bd[] += $tab_id[$i]['opportunity_title_id'];
    }
     
    print_r($tab_bd);
    echo "<br/>";
    print_r($tab_upd);
    echo "<hr/><hr/>";
     
    $tab_upd_inv = array();
    $tab_upd_inv = $tab_upd;
     
    print_r($result);
    $tab_del = array();
    $update = -1;
    // Vérifie ceux qui ont été sélectionné
    for($i=0;$i<count($tab_bd);$i++) {
    	foreach($tab_upd as $key => $value) {
    		echo "<br/>val_BD=>".$tab_bd[$i]." -- ".$tab_upd[$key];
    		if($tab_bd[$i] == $tab_upd[$key]) {
    			echo "<br/> ->".$tab_bd[$i]."--".count($tab_upd);
    			unset($tab_upd[$key]);
    			$update = 1;
    		}
    	}
    }
     
    print_r($tab_upd);
     
    echo "<hr/><hr/>";
    $update_inv = -1;
    // L'inverse pour vérifier ceux qui ont été déselectionné
    for($i=0;$i<count($tab_upd_inv);$i++) {
    	foreach($tab_bd as $key => $value) {
    		echo "<br/>val_upd=>".$tab_upd_inv[$i]." -- ".$tab_bd[$key];
    		if($tab_upd_inv[$i] == $tab_bd[$key]) { // L'inverse
    			echo "<br/> ->".$tab_upd_inv[$i]."--".count($tab_upd);
    			unset($tab_bd[$key]);
    			$update_inv = 1;
    		}
    	}
    }
     
    print_r($tab_bd);
     
    // Mise à jour 
    if($update) {
    	for($i=0;$i<count($tab_upd);$i++) {
    		$sql_update = 	"UPDATE opportunities_titles " .
    						"SET type_assign = '".$type."' ".
    						"WHERE opportunity_title_id = ".$tab_upd[$i];
    		$con->debug=1;
    		$rst = $con->execute($sql_update);
    	}
    }
    [...] Code en continuation [...]
    ?>
    Merci,

  4. #4
    Membre du Club
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    93
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2006
    Messages : 93
    Points : 49
    Points
    49
    Par défaut
    J'ai finalement trouvé une méthode voilà: c'est le même algo que l'autre pour la partie d'en haut mais c'est les updates qui changes

    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
     
    $type = $_POST['type_alias1'];
    $tab_lier = array();
     
    $tab_lier['opportunity_title'] = $_POST['assign_type'];
     
    $sql = "SELECT opportunity_title_id,opportunity_title_name,type_assign " .
    		"FROM opportunities_titles " .
    		"WHERE type_assign LIKE '".$type."' " .
    		"AND opportunity_title_record_status LIKE 'a'";
    $rst=$con->execute($sql);
     
    // Tableau
    $tab_bd = array();
    $tab_upd = array();
    $tab_id = array();
     
    $tab_id = $rst->GetArray();
    $tab_upd = $tab_lier['opportunity_title'];
     
    for($i=0;$i<count($tab_id);$i++) {
    	$tab_bd[] += $tab_id[$i]['opportunity_title_id'];
    }
     
    $tab_upd_inv = array();
    $tab_upd_inv = $tab_upd;
     
    // Vérifie ceux qui ont été sélectionné
    for($i=0;$i<count($tab_bd);$i++) {
    	foreach($tab_upd as $key => $value) {
    		if($tab_bd[$i] == $tab_upd[$key]) {
    			echo "<br/> ->".$tab_bd[$i]."--".count($tab_upd);
    			unset($tab_upd[$key]);
    		}
    	}
    }
     
    // L'inverse pour vérifier ceux qui ont été déselectionné
    for($i=0;$i<count($tab_upd_inv);$i++) {
    	foreach($tab_bd as $key => $value) {
    		if($tab_upd_inv[$i] == $tab_bd[$key]) {
    			echo "<br/> ->".$tab_upd_inv[$i]."--".count($tab_upd);
    			unset($tab_bd[$key]);
    		}
    	}
    }
     
     
    ////////////////////
    //Mise à jour 
    ////////////////////
    // Tableau des sélectionnés
    if(count($tab_upd)>0) {
    	foreach($tab_upd as $key => $value) {
    		$sql_update = 	"UPDATE opportunities_titles " .
    						"SET type_assign = '".$type."' ".
    						"WHERE opportunity_title_id = ".$tab_upd[$key];
    		//$con->debug=1;
    		$rst = $con->execute($sql_update);
    	}
    }
     
    // Tableau des non-sélectionnés
    if(count($tab_bd)>0) {
    	foreach($tab_bd as $key => $value) {
    		$sql_update = 	"UPDATE opportunities_titles " .
    						"SET type_assign = '' ".
    						"WHERE opportunity_title_id = ".$tab_bd[$key];
    		//$con->debug=1;
    		$rst = $con->execute($sql_update);
    	}
    }
    Mais j'aimerais bien me faire critiquer et avoir votre opinion. Donc je ne fermerai pas le post tout de suite.

    MERCI

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

Discussions similaires

  1. [1.x] Problème avec select multiple
    Par farhaenis dans le forum Symfony
    Réponses: 0
    Dernier message: 16/08/2011, 10h54
  2. Problème de select multiple
    Par dnd888 dans le forum Langage
    Réponses: 1
    Dernier message: 11/01/2011, 12h42
  3. problème avec selection multiple
    Par boboss123 dans le forum Composants
    Réponses: 0
    Dernier message: 04/06/2010, 15h12
  4. [DisplayTag] Problème de selection multiple checkbox avec spring mvc
    Par nean_j dans le forum Taglibs
    Réponses: 5
    Dernier message: 20/11/2009, 14h33
  5. Problème de select multiples dans plusieurs tables
    Par superseb801 dans le forum Requêtes
    Réponses: 3
    Dernier message: 10/05/2007, 02h22

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