Foros del Web » Programando para Internet » PHP »

Filtrar búsqueda por distintas cosas

Estas en el tema de Filtrar búsqueda por distintas cosas en el foro de PHP en Foros del Web. Hola a todos, Estoy haciendo un proyecto web en el cual necesito filtrar una busqueda de la siguiente manera: yo tengo productos cargados en mi ...
  #1 (permalink)  
Antiguo 06/10/2012, 21:57
 
Fecha de Ingreso: febrero-2012
Mensajes: 99
Antigüedad: 12 años, 9 meses
Puntos: 4
Filtrar búsqueda por distintas cosas

Hola a todos, Estoy haciendo un proyecto web en el cual necesito filtrar una busqueda de la siguiente manera:

yo tengo productos cargados en mi base de datos, y en mi web se muestran todos los productos y al lado un menu en el que se puede filtrar por Tipo(lacteo, carne, etc), gramos (entre 10g y 100g, entre 100g y 500g, mas de 500g)

MI problema es el siguiente: como puedo hacer para filtrarlo? LO que a mi se me ocurrio fue hacer un select y que tenga un where. pero como hago para filtrar por lo que el usuario indica?

Lo que quiero hacer seria un estilo como el que tiene mercadolibre, en el cual podes filtrar por varias cosas. saludos
  #2 (permalink)  
Antiguo 06/10/2012, 22:01
Avatar de rodrigo791  
Fecha de Ingreso: noviembre-2009
Ubicación: Uruguay
Mensajes: 1.339
Antigüedad: 15 años
Puntos: 168
Respuesta: Filtrar búsqueda por distintas cosas

select * from tabla where tipo = $TIPO

donde $TIPO es la variable que contiene el tipo que elige el usuario.
  #3 (permalink)  
Antiguo 06/10/2012, 22:06
 
Fecha de Ingreso: febrero-2012
Mensajes: 99
Antigüedad: 12 años, 9 meses
Puntos: 4
Respuesta: Filtrar búsqueda por distintas cosas

claro, lo que yo pensaba es hacer esto:

select * from tabla where tipo = $TIPO and gramos=$gramos

el problema es: si el usuario solo filtra por gramos? me traeria todo sin importar el tipo?
  #4 (permalink)  
Antiguo 06/10/2012, 22:12
Avatar de rodrigo791  
Fecha de Ingreso: noviembre-2009
Ubicación: Uruguay
Mensajes: 1.339
Antigüedad: 15 años
Puntos: 168
Respuesta: Filtrar búsqueda por distintas cosas

son consultas diferentes.
una te filtra por tipo, otra te filtra por gramos.
Podes plantear condicionales, si el usuario eligio un tipo y un grano entonces haces la consulta tal cual la acabas de decir, pero si solo eligió tipo y no gramos, haces como te dije yo.
  #5 (permalink)  
Antiguo 06/10/2012, 22:19
 
Fecha de Ingreso: febrero-2012
Mensajes: 99
Antigüedad: 12 años, 9 meses
Puntos: 4
Respuesta: Filtrar búsqueda por distintas cosas

Y pero si tengo varios filtros?

Por ejemplo:
precio
gramos
letras
palabras
colores

con esto deberia hacer un monton de combinaciones.... debe haber alguna otra forma
  #6 (permalink)  
Antiguo 06/10/2012, 22:28
Avatar de mko
mko
 
Fecha de Ingreso: agosto-2010
Ubicación: la vida es un riesgo
Mensajes: 101
Antigüedad: 14 años, 3 meses
Puntos: 14
Respuesta: Filtrar búsqueda por distintas cosas

y si en lugar de hacer eso usas (OR) y like y con los comodines:

select * from tabla where tipo like "%$tipo%" OR gramos like "%$tipo%"

solo agregas tus campos q necesitas y con eso sale todo en una misma cosulta



select * from usuario where nombre like "%luis%"


Eso devuelve todos los usuarios que tienen "luis" en algún lugar del campo nombre. Nos sevolvería los registros con nombres como "luis", "luis alberto" o "jose luis".

eso haria un poco mejor tu filtro
__________________
cuando no esperas nada y obtienes todo eso es destino
  #7 (permalink)  
Antiguo 06/10/2012, 22:38
 
Fecha de Ingreso: febrero-2012
Mensajes: 99
Antigüedad: 12 años, 9 meses
Puntos: 4
Respuesta: Filtrar búsqueda por distintas cosas

Hola, gracias por la respuesta pero el problema no es ese. el problema es como generar la consulta sabiendo que el usuario puede querer filtrar de distintas formas (tal vez un usuario le gusta filtrar solo por tipo, a otro por tipo y por gramos y a otro por gramos, colores y letras)
  #8 (permalink)  
Antiguo 06/10/2012, 22:41
Avatar de mko
mko
 
Fecha de Ingreso: agosto-2010
Ubicación: la vida es un riesgo
Mensajes: 101
Antigüedad: 14 años, 3 meses
Puntos: 14
Respuesta: Filtrar búsqueda por distintas cosas

Cita:
Iniciado por brai_lf Ver Mensaje
Hola, gracias por la respuesta pero el problema no es ese. el problema es como generar la consulta sabiendo que el usuario puede querer filtrar de distintas formas (tal vez un usuario le gusta filtrar solo por tipo, a otro por tipo y por gramos y a otro por gramos, colores y letras)
bueno no veo donde esta tu problema
puedes poner un solo campo y en el cual el usuairo teclee lo q guste e internamente tu realizas la consulta por todos los campos de tu tabla asi seria mas factible y con un unico archivo si necesidad de hacer tantos script
__________________
cuando no esperas nada y obtienes todo eso es destino
  #9 (permalink)  
Antiguo 06/10/2012, 22:44
 
Fecha de Ingreso: febrero-2012
Mensajes: 99
Antigüedad: 12 años, 9 meses
Puntos: 4
Respuesta: Filtrar búsqueda por distintas cosas

Pero la idea no es esa, la idea es darle comodidad al usuario para que no teclee nada y pueda filtrar como guste
  #10 (permalink)  
Antiguo 06/10/2012, 22:48
Avatar de mko
mko
 
Fecha de Ingreso: agosto-2010
Ubicación: la vida es un riesgo
Mensajes: 101
Antigüedad: 14 años, 3 meses
Puntos: 14
Respuesta: Filtrar búsqueda por distintas cosas

aver aver q ya me perdistes
solo quieres q el usuario elija los campos de la tabla y q esos campo se vean en la consulta
explicame bien y lo podemos solucionar ya q lo q deceas no es muy dificil
__________________
cuando no esperas nada y obtienes todo eso es destino

Última edición por mko; 06/10/2012 a las 23:09
  #11 (permalink)  
Antiguo 06/10/2012, 23:16
 
Fecha de Ingreso: febrero-2012
Mensajes: 99
Antigüedad: 12 años, 9 meses
Puntos: 4
Respuesta: Filtrar búsqueda por distintas cosas

Hola, primero que nada gracias por la buena onda. Paso a explicarte:

al usuario se le muestra una lista con todos los productos.

al lado de la lista esta lo siguiente:

Ubicacion
-Paternal
-Palermo
-Villa Crespo

Cantidad
-Entre 1 y 5
-+ de 5

Color:
-Blanco
-Negro
-Rojo
-Gris

Lo que yo quiero es que el usuario decida por que filtrar. puede ser que el usuario quiera que este en paternal, q la cantidad sea mas de 5 y color rojo

o puede ser que quiera solo de color rojo (sin importar cantidad ni ubicacion)

o puede ser que quiera que este paternal y blanco (sin importar la cantidad)

o lo que el usuario quiera, pero que tenga la posibilidad de elegir.
  #12 (permalink)  
Antiguo 07/10/2012, 09:11
Avatar de mko
mko
 
Fecha de Ingreso: agosto-2010
Ubicación: la vida es un riesgo
Mensajes: 101
Antigüedad: 14 años, 3 meses
Puntos: 14
Respuesta: Filtrar búsqueda por distintas cosas

perfecto:
ahora la pregunta: ubicacion, color y cantidad van a ser estaticos es decir los datos q solicitas no van aumentar es decir no va aparecer por ejemplo color:amarrillo, u otra cosa es decir no van aser dinamicos
ahora la solucion es muy sencilla en un form
pones esos datos en select: ya que me dices q el usuario no debe teclear nada(mas bien yo pensaba en un buscador anterior mente estaba enrredando)
agroso modo te quedaria asi: luego realizas la sisntaxis voy de salida ...........
ahor suponiendo q el enviolo haces en php sin ajax seria algo como esto

form id="filtro" action="recibe.php" metodo=post
select id="tipo"
los llenas
/selet

select id="cantidad"
los llenas
/selet


select id="color"
los llenas
/selet

//aqui un boton de envio un sumbit
/form


--------------------------recibe.php-----------------------
$color=recisbe las vaibles esos supongo yua sabes hacerlo
$tipo=recisbe las vaibles esos supongo yua sabes hacerlo
$cantidad=recisbe las vaibles esos supongo yua sabes hacerlo

//esta es la sintaxis sql:agregale el query y la sintaxix correcta en php

select * from tabla where tipo like "%$tipo%" OR gramoslike "%$cantidad%" OR color like "%$color%"
despues aver realizado la consutla

imprimes los datos
(al usar OR no importa si uno de los datos viene vacio la consulta se hace amenos que el usuario no mande nada para lo cual tendrsq ue validar a que por lo menos elusuario seleccione un selet)
ve la tabla de verdd del OR para que te des mas idea del funcionamiento


ahora agroso modo eso debe solucionar tu problema cheklo y me dices q ondas
y disculpa pero np tengo mucho tiempo para redactar bien........
__________________
cuando no esperas nada y obtienes todo eso es destino

Última edición por mko; 07/10/2012 a las 09:27
  #13 (permalink)  
Antiguo 08/10/2012, 10:42
 
Fecha de Ingreso: febrero-2012
Mensajes: 99
Antigüedad: 12 años, 9 meses
Puntos: 4
Respuesta: Filtrar búsqueda por distintas cosas

Genial, so si que fue de gran ayua. muchas gracias

Etiquetas: cosas, distintas, filtrar, usuarios
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 11:23.