Foros del Web » Programando para Internet » PHP »

Consulta SQL atraves de combos dinamicos

Estas en el tema de Consulta SQL atraves de combos dinamicos en el foro de PHP en Foros del Web. Hola, he estado mirando en las FAQ's y encontre un script ke posteo Cluster para hacer combos dinamicos, pues bien he tratado de adaptar dicho ...
  #1 (permalink)  
Antiguo 02/03/2006, 16:00
Avatar de ZydRick  
Fecha de Ingreso: febrero-2005
Ubicación: Lima
Mensajes: 750
Antigüedad: 19 años, 2 meses
Puntos: 4
Consulta SQL atraves de combos dinamicos

Hola, he estado mirando en las FAQ's y encontre un script ke posteo Cluster para hacer combos dinamicos, pues bien he tratado de adaptar dicho codigo a un script ke estoy haciendo para hacer una consulta ke me muestra Origen y Destino para una agencia de viajes en la tabla tabla_padre puse la ciudades de origen y en la tabla_hija las ciudades de destino relacionadas siempre por la id de la tabla_padre, la consulta como es logico en ese script me arroja las id seleccionadas de ambas tablas, ahora el detalle, lo ke yo kisiera es ke en lugar de ke me mostrase las ID me muestre el nombre de las ciudades seleccionadas, le he estado dando miles de vueltas pero no pude tener exito, aki dejo el codigo de dicha FAQ, para ver si alguno ke este mas enterado del tema me eche una mano y ver donde podria modificar para obtener el resultado ke necesito

Código PHP:
<?php
// datos de conexion a la BD.
$servidor  ="localhost"// host
$usuario   =""
$clave     ="";
$basedatos =""// Indicar una Base de datos.

// si se ha pulsao el boton enviar ($enviado) se procesa el formulario ..
// Sino, se continua con el formulario y los nuevos valores de los Select ..
// OJO si se tienen mas varibles (mas <input> ) se van a perder sus valores a no ser
// que los obtengamos y se les de como valor inicial en el value= de cada uno segun corresponda.

if (!empty($_POST['enviado'])){

// Procesar el formulario ...
echo "Procesando formulario:<br>";
echo 
"Recibido id_tabla_padre: ".$_POST['id_padre']."<br>";
echo 
"Recibido id_tabla_hija: ".$_POST['id_hija'];

} else {

   
// Conexión a la BD
   
$conexion mysql_connect($servidor$usuario$clave) or die(mysql_error());
   
mysql_select_db($basedatos$conexion) or die(mysql_error());

   
// Obtener el $id_padre del envio a si mismo del formulario ..
   
$id_padre=$_POST['id_padre'];

   
// Inicio Formulario .. PHP_SELF enviamos a si mismo (a este script).
   
echo "<form action=\"".$_SERVER['PHP_SELF']."\" method=\"POST\">\n\n";

   
// Formar Selec "Padre".
   
echo "<select name=\"id_padre\" onChange=\"this.form.submit()\">\n";
   echo 
"<option value=\"\"> Seleccione un Item </option>\n";

   
$SQLconsulta_padre="SELECT * FROM tabla_padre";
   
$consulta_padre mysql_query($SQLconsulta_padre,$conexion) or die(mysql_error());

   While   (
$registro_padre=mysql_fetch_assoc($consulta_padre)){
      
// Se mira si el ID del registro es el mismo q el $id_padre q recibimos si hemos cambiado el select hijo.
      // Se selecciona en consecuencia (selected) la opción elegida.
      
if ($id_padre == $registro_padre['id']){
         echo 
"<option value=\"".$registro_padre['id']."\" selected>".$registro_padre['item_texto']."</option>\n";
      } else {
         echo 
"<option value=\"".$registro_padre['id']."\">".$registro_padre['item_texto']."</option>\n";
      }
    }
   echo 
"</select>\n\n";

   
mysql_free_result($consulta_padre); // Liberar memoria usada por consulta.

   // Formar Select "Hijo"
   
echo "<select name=\"id_hija\">\n";

   
// Si $id_padre no tiene valor (caso de que no se ha seleccionado ningua opcion del select hijo
   // se muestra el mensaje de "seleccine un item" (del select padre).
   
if (!empty($id_padre)){

       
$SQLconsulta_hija="SELECT * FROM tabla_hija WHERE id_padre='$id_padre'";
       
$consulta_hija mysql_query($SQLconsulta_hija,$conexion) or die(mysql_error());
       
// se mira el total de registros de la consulta .. si es 0 se muestra mensaje en el select ..
       
if (mysql_num_rows($consulta_hija) != 0){
          While   (
$registro_hija=mysql_fetch_assoc($consulta_hija)){
            echo 
"<option value=\"".$registro_hija['id']."\">".$registro_hija['item_texto']."</option>\n";
          }
        } else {
            echo 
"<option value=\"\"> No hay registros para este Item </option>";
        }
    } else {
        echo 
"<option value=\"\"> <-- Seleccione un Item  </option>";
    }

    
mysql_free_result($consulta_hija); // Liberar memoria usada por consulta.
    
    
echo "</select>\n\n";
    echo 
"<input type=\"submit\" name=\"enviado\" value=\" Enviar \" >\n\n";
    echo 
"</form>\n";

?>
Espero ke alguien me pueda ayudar a optimizar dicho codigo, gracias de antemano, saludos
  #2 (permalink)  
Antiguo 02/03/2006, 20:03
Avatar de Mickel  
Fecha de Ingreso: mayo-2002
Ubicación: Lima, Peru
Mensajes: 4.619
Antigüedad: 21 años, 11 meses
Puntos: 7
Por si AJAX te sirve: http://www.mickel.biz/ajax/ajax1.php
__________________
No tengo firma ahora... :(
  #3 (permalink)  
Antiguo 03/03/2006, 11:46
Avatar de ZydRick  
Fecha de Ingreso: febrero-2005
Ubicación: Lima
Mensajes: 750
Antigüedad: 19 años, 2 meses
Puntos: 4
gracias Mikel por ese script, lo voy a mirar a ver ke tal va, pero de momento si alguno pueda ayudarme con el codigo ke puse arriba pues se lo agradecere mucho

saludos
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta

SíEste tema le ha gustado a 1 personas (incluyéndote)




La zona horaria es GMT -6. Ahora son las 16:11.