Foros del Web » Programando para Internet » PHP »

Busqueda en varios campos

Estas en el tema de Busqueda en varios campos en el foro de PHP en Foros del Web. Hola a todos, se que a lo mejor ya esta resuelto pero me la he pasado buscando y no encuentro nada. estas son mis formas: ...
  #1 (permalink)  
Antiguo 05/06/2013, 14:24
 
Fecha de Ingreso: junio-2013
Mensajes: 1
Antigüedad: 11 años, 5 meses
Puntos: 0
Busqueda en varios campos

Hola a todos, se que a lo mejor ya esta resuelto pero me la he pasado buscando y no encuentro nada.
estas son mis formas:
Código HTML:
<form id="form1" name="form1" method="post" action="buscanac.php">
        <table width="680" border="0" align="center">
          <tr>
            <td width="186" align="right" class="fuenteOp">Nombre:</td>
            <td width="304"><span id="sprytextfield1">
              <input name="nom" type="text" id="nom" size="50" maxlength="60" />
            </span></td>
          </tr>
          <tr>
            <td align="right" class="fuenteOp">Apellido Paterno:</td>
            <td><span id="sprytextfield2">
              <input name="apepa" type="text" id="apepa" size="40" maxlength="50" />
            </span></td>
          </tr>
          <tr>
            <td align="right" class="fuenteOp">Apellido Materno:</td>
            <td><span id="sprytextfield3">
              <input type="text" name="apema" id="apema" size="40" maxlength="50" />
            </span></td>
          </tr>
          <tr>
            <td align="right" class="fuenteOp">&nbsp;</td>
            <td>&nbsp;</td>
          </tr>
          <tr>
            <td align="right" class="fuenteOp">Fecha de Nacimiento:</td>
            <td><span id="spryselect1">
              <select name="strdia">
              	<option value=01>01</option>
                <option value=02>02</option>
                <option value=03>03</option>
                <option value=04>04</option>
                <option value=05>05</option>
                <option value=06>06</option>
                <option value=07>07</option>
                <option value=08>08</option>
                <option value=09>09</option>
                <option value=10>10</option>
                <option value=11>11</option>
                <option value=12>12</option>
                <option value=13>13</option>
                <option value=14>14</option>
                <option value=15>15</option>
                <option value=16>16</option>
                <option value=17>17</option>
                <option value=18>18</option>
                <option value=19>19</option>
                <option value=20>20</option>
                <option value=21>21</option>
                <option value=22>22</option>
                <option value=23>23</option>
                <option value=24>24</option>
                <option value=25>25</option>
                <option value=26>26</option>
                <option value=27>27</option>
                <option value=28>28</option>
                <option value=29>29</option>
                <option value=30>30</option>
                <option value=31>31</option>
                </select> 
              
              <select name="strmes">
              <option value=01>Ene</option>
              <option value=02>Feb</option>
              <option value=03>Mar</option>
              <option value=04>Abr</option>
              <option value=05>May</option>
              <option value=06>Jun</option>
              <option value=07>Jul</option>
              <option value=08>Ago</option>
              <option value=09>Sep</option>
              <option value=10>Oct</option>
              <option value=11>Nov</option>
              <option value=12>Dic</option>
              </select>
              <input type="text" name="stranio" maxlength="4" size="5" value=""> 
              <span class="fuentesobl">Obligatorio.</span>
              <span class="selectRequiredMsg"></span></span> 
Tengo este código php, que se basa en una busqueda de 6 campos sobre una tabla en mysql

Código PHP:
$dbhost "host"// El host
$dbuser "user"// El usuario
$dbpass "clave"// El Pass
$db "bd"// Nombre de la base

$connect mysql_connect($dbhost,$dbuser,$dbpass); // se conecta con la db
mysql_select_db($db,$connect)or die(mysql_error());
$nom=$_POST["nombre"];
$apa=$_POST["apepa"];
$ama=$_POST["apema"];
$sex=$_POST["sexo"];
$di=(int)$_POST["strdia"];
$me=(int)$_POST["strmes"];
$an=(int)$_POST["stranio"];
$mun=$_POST["municipio"];

$consulta="SELECT nombre,apepa,apema,fechanacdia,fechanacmes,fechanacanio,localidad FROM nac where nombre like '%$nom%' and apepa like '%$apa%' and apema like '%$ama%' and fechanacdia='$di' and fechanacmes='$me' and fechanacanio='$an'";


$query=mysql_query($consulta,$connect);
echo 
$consulta;
$colo='#FFFFFF';
echo 
"<table border='1' cellpadding='4' cellspacing='0' align='center' class='fuentetxt' bgcolor='$colo'>";
echo 
"<tr><td>Nombre</td><td>Apellido Paterno</td><td>Apellido Materno</td><td>Día</td><td>Mes</td><td>Año</td><td>Municipio</td></tr>";
while (
$reg=mysql_fetch_row($query)){
    echo 
"<tr><td>";
    echo 
$consulta['nom'];
    echo 
"</td><td>";
    echo 
$consulta['apa']; 
    echo 
"</td><td>";
    echo 
$consulta['ama']; 
    echo 
"</td><td>";
    echo 
$consulta['di']; 
    echo 
"</td><td>";
    echo 
$consulta['me']; 
    echo 
"</td><td>";
    echo 
$consulta['an']; 
    echo 
"</td><td>";
    echo 
$consulta['mun']; 
    echo 
"</td></tr>"
    

    foreach(
$reg as $cambia){
        print 
"<td><div style='padding-left:22px; padding-top:9px; padding-right:10px ' class='fuentetxt' align='justify'>".utf8_encode($cambia) . "</td></div>";
        

    }
}
if (
$colo=="#FFFFFF"){
        
$colo="#99CCFF";
            }else{
               
$colo"#FFFFFF";
                    }
echo 
"</table>";



?> 
y no me mustra nada, la tabla me la manda vacía sin info, imprimo el resultado para ver que datos estoy enviando al selecty nada de nada.
este es la impresión del resultado

Código:
SELECT nombre,apepa,apema,fechanacdia,fechanacmes,fechanacanio,localidad FROM nac where nombre like '%%' and apepa like '%%' and apema like '%%' and fechanacdia='0' and fechanacmes='0' and fechanacanio='0'
Les agradezco su ayuda, para resolver el problema. Saludos
  #2 (permalink)  
Antiguo 05/06/2013, 14:43
Avatar de wizanchez  
Fecha de Ingreso: junio-2013
Ubicación: bogota
Mensajes: 120
Antigüedad: 11 años, 5 meses
Puntos: 6
Respuesta: Busqueda en varios campos

- utiliza $_REQUEST[''] en ves de $_POST[""];

- no veo nada raro en tu codigo
  #3 (permalink)  
Antiguo 05/06/2013, 15:06
Avatar de Nemutagk
Colaborador
 
Fecha de Ingreso: marzo-2004
Ubicación: México
Mensajes: 2.633
Antigüedad: 20 años, 7 meses
Puntos: 406
Respuesta: Busqueda en varios campos

Debe evitarse en lo posible usar $_REQUEST por medidas de seguridad...

Es obvio que no te retorne registros ya que usas AND entre campos por lo cual con tu sentencia SQL le estas diciendo:

Devuélveme los registros que:
nombre like '%%' = nombre este vacio
apepa like '%%' = apepa este vacío
apema like '%%' = apema este vácio
fechanacdia='0' = fechancida sea 0
fechanacmes='0' = fechanacmes sea 0
fechanacanio='0' = fechaacanio sea 0

A lo que me refiero es que si no tienes registros que sean similares a TODOS los valores pasados no te retornará registros, en vez de AND usa OR...
__________________
Listo?, tendría que tener 60 puntos menos de IQ para considerarme listo!!!
-- Sheldon Cooper
http://twitter.com/nemutagk
PD: No contestaré temas vía mensaje personal =)
  #4 (permalink)  
Antiguo 05/06/2013, 15:09
Avatar de anacona16  
Fecha de Ingreso: marzo-2010
Ubicación: Bogota DC
Mensajes: 610
Antigüedad: 14 años, 8 meses
Puntos: 52
Respuesta: Busqueda en varios campos

Talvez no vaya al tema pero te recomiendo esta clase para hacer un buscador... http://objetivophp.com/?p=104
__________________
Aprendiendo!!!

Etiquetas: busqueda, campos, mysql, select, sql, tabla
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 22:10.