Foros del Web » Programando para Internet » PHP »

Buscador avanzado

Estas en el tema de Buscador avanzado en el foro de PHP en Foros del Web. Hoa de nuevo a todos, de echo hacia tiempo que no andaba por aquí, eso es buena señal...estoy aprendiendo. Tengo un problema, haber... quiero hacer ...
  #1 (permalink)  
Antiguo 11/12/2004, 13:40
 
Fecha de Ingreso: noviembre-2002
Mensajes: 130
Antigüedad: 21 años, 5 meses
Puntos: 0
Buscador avanzado

Hoa de nuevo a todos, de echo hacia tiempo que no andaba por aquí, eso es buena señal...estoy aprendiendo.

Tengo un problema, haber... quiero hacer un buscador avanzado, no como el que aparace en esta web, que es impresionante,pero si por el estilo. Con un campo de busqueda y tres o 4 <select> donde lista provincia, tipo de inmueble, tipo de operación y fecha.

Un buscador sencillo lo hago funcionar. Pero avanzado eso ya es otra cosa.
Si saben de algun tutorial o me pueden echar un cable sería perfecto.

gracias
  #2 (permalink)  
Antiguo 13/12/2004, 06:17
O_O
 
Fecha de Ingreso: enero-2002
Ubicación: Santiago - Chile
Mensajes: 34.417
Antigüedad: 22 años, 3 meses
Puntos: 129
Pero .. tienes que definir en que hay que "buscar" .. no es lo mismo hablar de "buscar" sobre contenido almacenado en una Base de datos donde lo que vas hacer son "consultas SQL" a tu BD .. que tener ese "contenido" suceptible de ser buscado en páginas HTML .. o en otros médios.

Un saludo,
  #3 (permalink)  
Antiguo 13/12/2004, 10:52
 
Fecha de Ingreso: noviembre-2002
Mensajes: 130
Antigüedad: 21 años, 5 meses
Puntos: 0
Son datos que hay que buscar en base de batos.
el codigo es el siguiente...

Código PHP:
<form action="<? echo $PHP_SELF ?>" method="post">
<table width="100%" height="80%"  border="0" align="center" cellpadding="2" cellspacing="2" bgcolor="#FFFFFF" class="menu-text">
                <tr>
                  <td align="right" valign="top" class="menu-text"><div align="right"></div></td>
                  <td><div align="right">Buscar palabra: </div></td>
                <td><input name="nombre" type="text" class="input" size="20" vale"<?php echo "$nombre";?>"> </td>
                </tr>
                <tr>
                  <td colspan="3" class="menu-text"><div align="center">&nbsp;
                  </div></td>
                </tr>
                <tr>
                  <td height="10" colspan="3" align="right" valign="top" class="topictext"></td>
                </tr>
                <tr>
                  <td align="right" class="menu-text">&nbsp;</td>
                  <td><div align="right">Poblaci&oacute;n:</div></td>
                  <td><select class="input" name="poblacion">
                    <option selected>Seleccionar Poblaci&oacute;n</option>
                    <option></option>
                    <?
        $result 
mysql_query("SELECT * FROM jcm_poblacion order by nombre");
        while(
$row mysql_fetch_row($result)) {
    
?>
                    <option value="<?php echo $row[id]; ?>"><?php echo $row[poblacion]; ?></option>
                    <?php
                    
}
                    
?>
                  </select></td>
                  </tr>
                <tr>
                  <td align="right" class="menu-text">&nbsp;</td>
                  <td><div align="right">Tipo de Inmueble:</div></td>
                  <td><select class="input" name="tipoinmueble">
                    <option selected>Seleccionar Inmueble</option>
                    <option></option>
                    <?
                    $result 
mysql_query("SELECT * FROM jcm_tipoinmueble");
                    while(
$row mysql_fetch_row($result)) {
                    
?>
                    <option value="<?php echo $row[id]; ?>"><?php echo $row[tipoinmueble]; ?></option>
                    <?php
                    
}
                    
?>
                  </select></td>
                  </tr>
                <tr>
                  <td align="right" class="menu-text">&nbsp;</td>
                  <td><div align="right">Tipo de Operaci&oacute;n:</div></td>
                  <td><select class="input" name="tipooperacion">
                    <option selected>Seleccionar Operaci&oacute;n</option>
                    <option></option>
                    <?
                    $result 
mysql_query("SELECT * FROM jcm_tipooperacion");
                    while(
$row mysql_fetch_row($result)) {
                    
?>
                    <option value="<?php echo $row[id]; ?>"><?php echo $row[tipooperacion]; ?></option>
                    <?php
                    
}
                    
?>
                  </select></td>
                  </tr>
                <tr>
                  <td height="10" colspan="3" align="right" class="topictext"></td>
                </tr>
                <tr>
                  <td align="right" class="menu-text">&nbsp;</td>
                  <td><div align="right">Precio:</div></td>
                <td><input name="precio" type="text" class="precio" size="30">
                  &euro; </td>
                </tr>
                <tr>
                  <td align="right" class="menu-text">&nbsp;</td>
                  <td colspan="2"><div align="center">
                    <input name="enviado" type="submit" id="enviado" value="Buscar">
                  </div></td>
                </tr>
              </table>
</form>

el problema es cuando lo recibo que solo me busca en el campo $nombre
  #4 (permalink)  
Antiguo 13/12/2004, 15:14
O_O
 
Fecha de Ingreso: enero-2002
Ubicación: Santiago - Chile
Mensajes: 34.417
Antigüedad: 22 años, 3 meses
Puntos: 129
Y donde tienes el código que muestra los resultados de tu busqueda .. donde usará esas variables: poblacion, nombre .. etc .. que generas en tu formulario (tanto las listas de opciones como los otros campos input text que ahí manejas)...

Si dices que "sólo busca" en tal campo . .supongo que harás una consulta SQL tipo:

Código PHP:
$sql="ELECT * FROM tabla WHERE nombre='":$_POST['nombre']."'"
Si es así .. te faltará indicar tus AND/OR para añadir tus "campo=$variable" ... como condicinoes para tu sentencia SQL.

Un saludo,
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 10:17.