par
pingoo » 15 août 2005, 14:38
Bonjour,
Voila mon problème, j'utilise deux listes déroulantes dynamiques alimentés par une base mysql.
Tout marche sans problème seulement quand je récupère les données sur une autre page elles sont inutilisables.
Comme j'assoicie une marque et ces modèles, le numéro de la marque et le bon par contre les modèle on tous le même numéro donc pour les différencier il faudrait que j'utilise un numéro auto-incrémenté que j'ai ajouté dans la base de donnée mais que je n'arrive pas à intégrer dans mon script.
Je sais pas si je suis assé clair.
Voici mon code (qui est celui du FAQ):
<?php
/* On récupère si elle existe la valeur de la région envoyée par le formulaire */
$idr = isset($_POST['marques'])?$_POST['marques']:null;
// Paramètres de la Connexion à la base MYSQL
include("connexauto.php");
/* On établit la connexion à MySQL avec mysql_pconnect() plutôt qu'avec mysql_connect()
* car on aura besoin de la connexion un peu plus loin dans le script */
$connexion = mysql_pconnect($serveur, $admin, $mdp);
if($connexion != false)
{
$choixbase = mysql_select_db($base, $connexion);
$sql1 = "SELECT `id_cat`, `marques`".
" FROM `marque_auto`".
" ORDER BY `id_cat`";
$rech_regions = mysql_query($sql1);
$code_region = array();
$region = array();
/* On active un compteur pour les régions */
$nb_regions = 0;
if($rech_regions != false)
{
while($ligne = mysql_fetch_assoc($rech_regions))
{
array_push($code_region, $ligne['id_cat']);
array_push($region, $ligne['marques']);
/* On incrémente de compteur */
$nb_regions++;
}
}
?>
<select name="marques" id="marque_auto" onchange="document.forms['chgdept'].submit();">
<option value="-1">Choisissez une marque</option>
<?php
for($i = 0; $i < $nb_regions; $i++)
{
?>
<option value="<?php echo($code_region[$i]); ?>"<?php echo((isset($idr) && $idr == $code_region[$i])?" selected=\"selected\"":null); ?>><?php echo($region[$i]); ?></option>
<?php
}
?>
</select><br>
</td>
</tr>
<tr>
<td align="right" height="35"><b>* Modèle :</b><br></td>
<td>
<?php
mysql_free_result($rech_regions);
/* On commence par vérifier si on a envoyé un numéro de région et le cas échéant s'il est différent de -1 */
if(isset($idr) && $idr != -1)
{
/* Cération de la requête pour avoir les départements de cette région */
$sql2 = "SELECT `idcat`, `types`, 'id_scat'".
" FROM `type_auto`".
" WHERE `idcat` = ". $idr ."".
" ORDER BY `id_scat`;";
if($connexion != false)
{
$rech_dept = mysql_query($sql2, $connexion);
/* Un petit compteur pour les départements */
$nd = 0;
/* On crée deux tableaux pour les numéros et les noms des départements */
$code_dept = array();
$nom_dept = array();
$n_dept = array();
/* On va mettre les numéros et noms des départements dans les deux tableaux */
while($ligne_dept = mysql_fetch_assoc($rech_dept))
{
array_push($code_dept, $ligne_dept['idcat']);
array_push($nom_dept, $ligne_dept['types']);
$nd++;
}
/* Maintenant on peut construire la liste déroulante */
?>
<select name="modele" id="type_auto">
<?php
for($d = 0; $d<$nd; $d++)
{
?>
<option value="<?php echo($code_dept[$d]); ?>"<?php echo((isset($dept_selectionne) && $dept_selectionne == $code_dept[$d])?" selected=\"selected\"":null); ?>><?php echo($nom_dept[$d]." "); ?></option>
<?php
}
?>
</select>
<?php
}
/* Un petit coup de balai */
mysql_free_result($rech_dept);
}
?>
</form>
<?php
/* Terminé, on ferme la connexion */
mysql_close($connexion);
}
else
{
/* Si on arrive là, c'est pas bon signe, il faut vérifier les
* paramètres de connexion, mot de passe, serveur pas démarré etc... */
?>
<p>Un incident s'est produit lors de la connexion à la base de données, veuiillez essayer à nouveau ultérieurement.</p>
<?php
}
?>
<input type="hidden" name="marques" value="<?php echo (isset($_POST['marques'])) ? $_POST['marques'] : null; ?>">
<input type="hidden" name="modele" value="<?php echo (isset($_POST['modele'])) ? $_POST['modele'] : null; ?>">
Merci pour votre aide
Bonjour,
Voila mon problème, j'utilise deux listes déroulantes dynamiques alimentés par une base mysql.
Tout marche sans problème seulement quand je récupère les données sur une autre page elles sont inutilisables.
Comme j'assoicie une marque et ces modèles, le numéro de la marque et le bon par contre les modèle on tous le même numéro donc pour les différencier il faudrait que j'utilise un numéro auto-incrémenté que j'ai ajouté dans la base de donnée mais que je n'arrive pas à intégrer dans mon script.
Je sais pas si je suis assé clair.
Voici mon code (qui est celui du FAQ):
[php]
<?php
/* On récupère si elle existe la valeur de la région envoyée par le formulaire */
$idr = isset($_POST['marques'])?$_POST['marques']:null;
// Paramètres de la Connexion à la base MYSQL
include("connexauto.php");
/* On établit la connexion à MySQL avec mysql_pconnect() plutôt qu'avec mysql_connect()
* car on aura besoin de la connexion un peu plus loin dans le script */
$connexion = mysql_pconnect($serveur, $admin, $mdp);
if($connexion != false)
{
$choixbase = mysql_select_db($base, $connexion);
$sql1 = "SELECT `id_cat`, `marques`".
" FROM `marque_auto`".
" ORDER BY `id_cat`";
$rech_regions = mysql_query($sql1);
$code_region = array();
$region = array();
/* On active un compteur pour les régions */
$nb_regions = 0;
if($rech_regions != false)
{
while($ligne = mysql_fetch_assoc($rech_regions))
{
array_push($code_region, $ligne['id_cat']);
array_push($region, $ligne['marques']);
/* On incrémente de compteur */
$nb_regions++;
}
}
?>
<select name="marques" id="marque_auto" onchange="document.forms['chgdept'].submit();">
<option value="-1">Choisissez une marque</option>
<?php
for($i = 0; $i < $nb_regions; $i++)
{
?>
<option value="<?php echo($code_region[$i]); ?>"<?php echo((isset($idr) && $idr == $code_region[$i])?" selected=\"selected\"":null); ?>><?php echo($region[$i]); ?></option>
<?php
}
?>
</select><br>
</td>
</tr>
<tr>
<td align="right" height="35"><b>* Modèle :</b><br></td>
<td>
<?php
mysql_free_result($rech_regions);
/* On commence par vérifier si on a envoyé un numéro de région et le cas échéant s'il est différent de -1 */
if(isset($idr) && $idr != -1)
{
/* Cération de la requête pour avoir les départements de cette région */
$sql2 = "SELECT `idcat`, `types`, 'id_scat'".
" FROM `type_auto`".
" WHERE `idcat` = ". $idr ."".
" ORDER BY `id_scat`;";
if($connexion != false)
{
$rech_dept = mysql_query($sql2, $connexion);
/* Un petit compteur pour les départements */
$nd = 0;
/* On crée deux tableaux pour les numéros et les noms des départements */
$code_dept = array();
$nom_dept = array();
$n_dept = array();
/* On va mettre les numéros et noms des départements dans les deux tableaux */
while($ligne_dept = mysql_fetch_assoc($rech_dept))
{
array_push($code_dept, $ligne_dept['idcat']);
array_push($nom_dept, $ligne_dept['types']);
$nd++;
}
/* Maintenant on peut construire la liste déroulante */
?>
<select name="modele" id="type_auto">
<?php
for($d = 0; $d<$nd; $d++)
{
?>
<option value="<?php echo($code_dept[$d]); ?>"<?php echo((isset($dept_selectionne) && $dept_selectionne == $code_dept[$d])?" selected=\"selected\"":null); ?>><?php echo($nom_dept[$d]." "); ?></option>
<?php
}
?>
</select>
<?php
}
/* Un petit coup de balai */
mysql_free_result($rech_dept);
}
?>
</form>
<?php
/* Terminé, on ferme la connexion */
mysql_close($connexion);
}
else
{
/* Si on arrive là, c'est pas bon signe, il faut vérifier les
* paramètres de connexion, mot de passe, serveur pas démarré etc... */
?>
<p>Un incident s'est produit lors de la connexion à la base de données, veuiillez essayer à nouveau ultérieurement.</p>
<?php
}
?>
<input type="hidden" name="marques" value="<?php echo (isset($_POST['marques'])) ? $_POST['marques'] : null; ?>">
<input type="hidden" name="modele" value="<?php echo (isset($_POST['modele'])) ? $_POST['modele'] : null; ?>">
[/php]
Merci pour votre aide