par
bbk974 » 01 août 2007, 14:30
merci beaucoup pour vos réponses même si mon cas n'est pas encore résolu!
Je me suis inspiré de la méthode php du tuto mais je ne connais pas les équivalences entre MySQL et Oracle. Je voudrai sélectionner un processus de la table "processes" qui me permettra de sélectionner une procédure de la table "procedures" parmis une liste de procédures liées au processus choisi.
///// indique que je ne connais pas l'équivalence
<?php
include "modules/adodb/adodb.inc.php";
include "config/config.php";
$db = NewADOConnection("oci8");
$cstr = "(DESCRIPTION=(ADDRESS=(PROTOCOL=$PROTOCOL)(HOST=$HOST)(PORT=$PORT))(CONNECT_DATA=(SID=$SID)))";
$db->Connect($cstr, $USER, $PWD);
$idr = isset($_POST['processes'])?$_POST['processes']:null;
?>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0//EN">
<html >
<head>
<title>Sélectionner un département selon le pprocessus choisi</title>
</head>
<body style="font-family: verdana, helvetica, sans-serif; font-size: 85%">
<?php
if(isset($_POST['ok']) && isset($_POST['procedures']) && $_POST['procedures'] != "")
{
$processes_selectionne = $_POST['processes'];
$procedures_selectionne = $_POST['procedures'];
?>
<p>Vous avez sélectionné la procédure <?php echo($procedures_selectionne); ?> dans la région <?php echo($processes_selectionne); ?></p>
<?php
}
?>
<h3>Trouver une procedure</h3>
echo'1';
<?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);
$req="SELECT * FROM processes ORDER BY idprocess";
$rech_processes = $db->Execute($req);
$code_processes = array();
$processes = array();
/* On active un compteur pour les processus */
$nb_process = 0;
if($rech_processes != false)
{
///// while($ligne = mysql_fetch_assoc($rech_processes))
{
array_push($code_processes, $ligne['idprocess']);
array_push($processes, $ligne['processes']);
/* On incrémente de compteur */
$nb_processes++;
}
}
?>
<form action="<?php echo($_SERVER['PHP_SELF']); ?>" method="post" id="chgprocedures">
<fieldset style="border: 3px double #333399">
<legend>Sélectionnez une région</legend>
<select name="processes" id="processes" onchange="document.forms['chgprocedures'].submit();">
<option value="-1">- - - Choisissez un processus - - -</option>
<?php
for($i = 0; $i < $nb_processes; $i++)
{
?>
<option value="<?php echo($code_processes[$i]); ?>"<?php echo((isset($idr) && $idr == $code_processes[$i])?" selected=\"selected\"":null); ?>><?php echo($processes[$i]); ?></option>
<?php
}
?>
</select>
<?php
///// mysql_free_result($rech_processes);
/* 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 */
$req2 = "SELECT `idprocedure`, `procedures`".
" FROM `procedures`".
" WHERE `idprocess` = ". $idr ."".
" ORDER BY `idprocedure`;";
if($connexion != false)
{
$rech_procedures = $db->Execute($req2);
/* Un petit compteur pour les procédures */
$nd = 0;
/* On crée deux tableaux pour les numéros et les noms des départements */
$code_procedures = array();
$nom_procedures = 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_procedures, $ligne_procedures['idprocedure']);
array_push($nom_procedures, $ligne_procedures['procedures']);
$nd++;
}
/* Maintenant on peut construire la liste déroulante */
?>
<select name="procedures" id="procedures">
<?php
for($d = 0; $d<$nd; $d++)
{
?>
<option value="<?php echo($code_procedures[$d]); ?>"<?php echo((isset($procedures_selectionne) && $procedures_selectionne == $code_procedures[$d])?" selected=\"selected\"":null); ?>><?php echo($nom_procedures[$d]." (". $code_procedures[$d] .")"); ?></option>
<?php
}
?>
</select>
<?php
}
/* Un petit coup de balai */
////// mysql_free_result($rech_dept);
}
?>
<br /><input type="submit" name="ok" id="ok" value="Envoyer" />
</fieldset>
</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&cuteest produit lors de la connexion à la base de données, veuiillez essayer à nouveau ultérieurement.</p>
<?php
}
?>
</body>
</html>
Merci encore
merci beaucoup pour vos réponses même si mon cas n'est pas encore résolu!
Je me suis inspiré de la méthode php du tuto mais je ne connais pas les équivalences entre MySQL et Oracle. Je voudrai sélectionner un processus de la table "processes" qui me permettra de sélectionner une procédure de la table "procedures" parmis une liste de procédures liées au processus choisi.
///// indique que je ne connais pas l'équivalence
[php]<?php
include "modules/adodb/adodb.inc.php";
include "config/config.php";
$db = NewADOConnection("oci8");
$cstr = "(DESCRIPTION=(ADDRESS=(PROTOCOL=$PROTOCOL)(HOST=$HOST)(PORT=$PORT))(CONNECT_DATA=(SID=$SID)))";
$db->Connect($cstr, $USER, $PWD);
$idr = isset($_POST['processes'])?$_POST['processes']:null;
?>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0//EN">
<html >
<head>
<title>Sélectionner un département selon le pprocessus choisi</title>
</head>
<body style="font-family: verdana, helvetica, sans-serif; font-size: 85%">
<?php
if(isset($_POST['ok']) && isset($_POST['procedures']) && $_POST['procedures'] != "")
{
$processes_selectionne = $_POST['processes'];
$procedures_selectionne = $_POST['procedures'];
?>
<p>Vous avez sélectionné la procédure <?php echo($procedures_selectionne); ?> dans la région <?php echo($processes_selectionne); ?></p>
<?php
}
?>
<h3>Trouver une procedure</h3>
echo'1';
<?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);
$req="SELECT * FROM processes ORDER BY idprocess";
$rech_processes = $db->Execute($req);
$code_processes = array();
$processes = array();
/* On active un compteur pour les processus */
$nb_process = 0;
if($rech_processes != false)
{
///// while($ligne = mysql_fetch_assoc($rech_processes))
{
array_push($code_processes, $ligne['idprocess']);
array_push($processes, $ligne['processes']);
/* On incrémente de compteur */
$nb_processes++;
}
}
?>
<form action="<?php echo($_SERVER['PHP_SELF']); ?>" method="post" id="chgprocedures">
<fieldset style="border: 3px double #333399">
<legend>Sélectionnez une région</legend>
<select name="processes" id="processes" onchange="document.forms['chgprocedures'].submit();">
<option value="-1">- - - Choisissez un processus - - -</option>
<?php
for($i = 0; $i < $nb_processes; $i++)
{
?>
<option value="<?php echo($code_processes[$i]); ?>"<?php echo((isset($idr) && $idr == $code_processes[$i])?" selected=\"selected\"":null); ?>><?php echo($processes[$i]); ?></option>
<?php
}
?>
</select>
<?php
///// mysql_free_result($rech_processes);
/* 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 */
$req2 = "SELECT `idprocedure`, `procedures`".
" FROM `procedures`".
" WHERE `idprocess` = ". $idr ."".
" ORDER BY `idprocedure`;";
if($connexion != false)
{
$rech_procedures = $db->Execute($req2);
/* Un petit compteur pour les procédures */
$nd = 0;
/* On crée deux tableaux pour les numéros et les noms des départements */
$code_procedures = array();
$nom_procedures = 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_procedures, $ligne_procedures['idprocedure']);
array_push($nom_procedures, $ligne_procedures['procedures']);
$nd++;
}
/* Maintenant on peut construire la liste déroulante */
?>
<select name="procedures" id="procedures">
<?php
for($d = 0; $d<$nd; $d++)
{
?>
<option value="<?php echo($code_procedures[$d]); ?>"<?php echo((isset($procedures_selectionne) && $procedures_selectionne == $code_procedures[$d])?" selected=\"selected\"":null); ?>><?php echo($nom_procedures[$d]." (". $code_procedures[$d] .")"); ?></option>
<?php
}
?>
</select>
<?php
}
/* Un petit coup de balai */
////// mysql_free_result($rech_dept);
}
?>
<br /><input type="submit" name="ok" id="ok" value="Envoyer" />
</fieldset>
</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&cuteest produit lors de la connexion à la base de données, veuiillez essayer à nouveau ultérieurement.</p>
<?php
}
?>
</body>
</html> [/php]
Merci encore