Foros del Web » Programando para Internet » PHP »

Filtro de datos

Estas en el tema de Filtro de datos en el foro de PHP en Foros del Web. Hola que tal. Soy nuevo en este foro al igual que php y mysql. Lo que quiero realizar es un filtro de datos a través ...
  #1 (permalink)  
Antiguo 05/10/2011, 12:04
 
Fecha de Ingreso: septiembre-2011
Mensajes: 34
Antigüedad: 12 años, 7 meses
Puntos: 0
Filtro de datos

Hola que tal.
Soy nuevo en este foro al igual que php y mysql.

Lo que quiero realizar es un filtro de datos a través de una lista desplegable.

He creado una tabla que se llama empleados, la cual tiene como campos:

CodEmp, Nombre, Categoria, Sueldo.

La lista desplegable debe llenarse con los nombres(Nombre) y cuando seleccione un nombre, me muestre el sueldo de este en un campo de texto.

Ahora bien, todo el codigo lo quiero hacer en una sola pagina a exepción de la conexion a la base de datos.

Hice esto:
Código PHP:
Ver original
  1. <html>
  2. <head>
  3. </head>
  4. <body>
  5.      
  6. <form action="" method="post">
  7.  
  8. <select  name="nombre">
  9.  
  10. <?php
  11. include("conecta.php");
  12.  
  13.  
  14. $sSQL="Select CodEmp, Nombre From empleados";
  15. $result=mysql_query($sSQL);
  16.  
  17. //Generamos el menu desplegable
  18. while ($row = mysql_fetch_array($result))
  19. {
  20.  
  21.      echo '<option value="' . $row['CodEmp'] . '">' . $row['Nombre'] . '</option>';
  22.  
  23. }
  24.  
  25. ?>
  26. </select>
  27.  
  28. <?php
  29. include("conecta.php");
  30.  
  31. $listaNombre = $_POST['nombre'];
  32.  
  33. $consulta = "Select * From empleados Where CodEmp ='$listaNombre'";
  34. $sueldo_editar = mysql_query($consulta) or die(mysql_error());
  35. $fila = mysql_fetch_array($sueldo_editar);
  36.  
  37. ?>
  38.  
  39. <br />
  40. <input type="text" name="Ver" value="<?php echo $fila['Sueldo']; ?>" />
  41. <!--<input type="button" value="Actualizar"/>-->
  42. </form>
  43.  
  44.  
  45.  
  46. </body>
  47. </html>

Pero me da este error:
Código HTML:
Ver original
  1. Notice: Undefined index: nombre in C:\wamp\www\Practicas\TraerDatos\Traer1.php on line 30

Ayudaaaaaaa Porfavor ya que no puedo salir de aqui . Gracias.
  #2 (permalink)  
Antiguo 05/10/2011, 12:21
Avatar de CesarHC  
Fecha de Ingreso: junio-2011
Ubicación: localhost
Mensajes: 566
Antigüedad: 12 años, 11 meses
Puntos: 56
Respuesta: Filtro de datos

Bueno un "notice" no afecta el funcionamiento de un script(a mi no me ha afectado), solo te esta indicando que no has definido "$_POST['nombre'];" si no me equivoco debes usar isset , por cierto tu codigo funciona o solo te vota eso?
__________________
Solo la práctica no te traicionara ¡¡¡¡¡¡

Seguir el camino tu debes PHP The Right Way.
  #3 (permalink)  
Antiguo 05/10/2011, 12:27
Avatar de Patriarka  
Fecha de Ingreso: enero-2011
Ubicación: Moreno, Buenos Aires, Argentina
Mensajes: 2.851
Antigüedad: 13 años, 3 meses
Puntos: 288
Respuesta: Filtro de datos

bueno lo tuyo es una cosa asi:
ya que son pocos datos lo unico que tenes que hacer ocultar el sueldo del empleado
y cuando seleccionas el nombre con el evento onchange de js mostras el div oculto
con un input donde se va a cargar el sueldo del empleado elegido
Código PHP:
Ver original
  1. <?php
  2. include("conecta.php");
  3. ?>
  4.     <html>
  5.     <head>
  6.     </head>
  7.     <body>
  8.  
  9.     <form action="" method="post">
  10.         <select  name="nombre">
  11.         <?php
  12.         $sSQL="Select CodEmp, Nombre, Sueldo From empleados";
  13.         $result=mysql_query($sSQL);
  14.         //Generamos el menu desplegable
  15.         while ($row = mysql_fetch_array($result))
  16.         {
  17.              echo '<option onchange="return verSueldo(' . $row['CodEmp'] . ');" value="' . $row['CodEmp'] . '">' . $row['Nombre'] . '</option>';
  18.         }
  19.         ?>
  20.         </select>
  21.         <br />
  22.         <?php
  23.         while ($fila = mysql_fetch_array($result)){
  24.         ?>
  25.             <input type="hidden" name="sueldo_<?php echo $fila['CodEmp']; ?>" value="<?php echo $fila['$fila']; ?>" />
  26.         <?php } ?>
  27.         <div style="display:none;" id="div_sueldo_<?php echo $fila['CodEmp']; ?>">
  28.             <input type="text" name="Ver" id="Ver" value="" />
  29.         </div>
  30.         <!--<input type="button" value="Actualizar"/>-->
  31.     </form>
  32.     </body>
  33.     </html>
  34. <script>
  35. function verSueldo(id_empleado){
  36.     var id_div_empleado = document.getElementById("sueldo_"+id_empleado).value;
  37.     document.getElementById("div_sueldo_"+id_empleado).style.display="block";
  38.     document.getElementById("dver").value=id_div_empleado;
  39. }
  40. </script>
  #4 (permalink)  
Antiguo 05/10/2011, 14:26
 
Fecha de Ingreso: julio-2010
Mensajes: 275
Antigüedad: 13 años, 10 meses
Puntos: 21
Respuesta: Filtro de datos

Te paso algo de un código que implementé alguna vez usando javascript y php... No recuerdo si funciona pero creo que va a ser de utilidad...

La función javascript (un script de javascript)
function lista(area) {
//mediante etiquetas php creamos el bucle que recorre la tabla
<?

$area='<script languaje="Javascript"> document.write(area)</script>';
include("../../Clases/conectar.php");//trae datos necesarios para establecer la conexion
$conexion = new Clsconexion_bd();
$conectar = $conexion->conexion();
$sql="select * from area as a, gerencia as b where a.cod_ger=b.cod_gerencia";
$ejecuta=pg_query($sql);
while ($reg = pg_fetch_object($ejecuta)){


?>
var cod_area = "<?= $reg->cod_area;?>"
var cod_area_ger = "<?=$reg->cod_ger; ?>";
var cod_ger = "<?= $reg->cod_gerencia;?>";
var nombre = "<?= $reg->nombre_gerencia; ?>";
if ( cod_area == area ) {
carga.gerencia.value=nombre; //<------ Aqui cambias el nombre por el de tu formulario, creo que debería ser formulario.gerencia.value=nombre;
}
<?
}
?>
}

Para el formulario con PHP y HTML:

<select size="1" cols="30" id="area" name="area" onchange = "javascript:lista(area.value);">
<option value="none">Seleccione un area</option>
<?
$conexion = new Clsconexion_bd();
$conectar = $conexion->conexion();

$sql="SELECT * FROM area WHERE TRUE ORDER BY nombre";
$ejecuta=pg_query($sql);
while ($reg = pg_fetch_object($ejecuta)){
?>
<option value="<?= $reg->cod_area; ?>"><? echo $reg->nombre; ?></option>
</select>

Última edición por Sirrohan; 05/10/2011 a las 14:30 Razón: Cambio de parámetros
  #5 (permalink)  
Antiguo 06/10/2011, 06:29
 
Fecha de Ingreso: septiembre-2011
Mensajes: 34
Antigüedad: 12 años, 7 meses
Puntos: 0
Respuesta: Filtro de datos

Gracias por responder.

Cita:
Bueno un "notice" no afecta el funcionamiento de un script(a mi no me ha afectado), solo te esta indicando que no has definido "$_POST['nombre'];" si no me equivoco debes usar isset , por cierto tu codigo funciona o solo te vota eso?
El codigo solo me muestra la lista desplegable y mas abajo me muestra el NOTICE.

con respecto al isset, de que forma lo implementaria y el onchange para que sirve.

Disculpa mi ignorancia, pero soy nuevo en PHP y aún no entro en el mundo de JavaScript.

Etiquetas: html, mysql, sql, tabla, filtros
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




La zona horaria es GMT -6. Ahora son las 09:02.