Précédent   Forum des professionnels en informatique > PHP > Langage > Formulaires
Formulaires Forum d'entraide sur les formulaires avec PHP. Avant de poster -> FAQ formulaires, Cours de formulaires et Sources de formulaires
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 31/01/2008, 17h04   #1
Membre à l'essai
 
Inscription : avril 2006
Messages : 93
Détails du profil
Informations forums :
Inscription : avril 2006
Messages : 93
Points : 21
Points : 21
Par défaut Problème de select multiple + database

Salut, j'utilise un formulaire de ce type
Code :
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,
thomfort est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 31/01/2008, 20h58   #2
Membre émérite
 
Avatar de julien.63
 
Inscription : décembre 2005
Messages : 1 322
Détails du profil
Informations forums :
Inscription : décembre 2005
Messages : 1 322
Points : 981
Points : 981
Envoyer un message via MSN à julien.63
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 :
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>
julien.63 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 31/01/2008, 23h26   #3
Membre à l'essai
 
Inscription : avril 2006
Messages : 93
Détails du profil
Informations forums :
Inscription : avril 2006
Messages : 93
Points : 21
Points : 21
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 :
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,
thomfort est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 31/01/2008, 23h50   #4
Membre à l'essai
 
Inscription : avril 2006
Messages : 93
Détails du profil
Informations forums :
Inscription : avril 2006
Messages : 93
Points : 21
Points : 21
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 :
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
thomfort est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 18h25.


 
 
 
 
Partenaires

Hébergement Web