Foros del Web » Programando para Internet » PHP »

[SOLUCIONADO] Filtrar resultados cuando se selecciona ALL en varios select

Estas en el tema de Filtrar resultados cuando se selecciona ALL en varios select en el foro de PHP en Foros del Web. Hola! Muy buenas a todos! Tengo un problema que me esta dando quebraderos de cabeza durante varios dias.. y no consigo resolverlo. Tengo un formulario ...
  #1 (permalink)  
Antiguo 14/08/2013, 14:19
 
Fecha de Ingreso: agosto-2013
Mensajes: 5
Antigüedad: 10 años, 8 meses
Puntos: 1
Pregunta Filtrar resultados cuando se selecciona ALL en varios select

Hola! Muy buenas a todos!

Tengo un problema que me esta dando quebraderos de cabeza durante varios dias.. y no consigo resolverlo.
Tengo un formulario con 6 Select y un boton de enviar. Como opcion preseleccionada para los 6 tengo ALL. Cuando se envia esta opcion ALL a la base de datos logicamente no puede ser consultada y me tiene que mostrar todos los resultados. Si tengo un Select que pone precio y la tabla es integer no puede buscar la palabra ALL. (En este caso se tiene que omitir la busqueda de este select en concreto). Con un Select solo que pone ALL es facil, filtrarlo con un if; pero cuando son 6 y hay muchisimas combinaciones no se domo hacerlo. Habia pensado algo asi pero no me funciona...


Código PHP:
include 'conexion.php';

    
$where = array();
     
    if(
$categoria!="ALL"){
        
array_push($where,' Categoria = "'.$categoria.'" ');
    };
    
    if(
$peso!="ALL"){
       
array_push($where,' Peso = "'.$peso.'" ');
    };
    
    
    if(
$duracion="ALL"){
        
array_push($where,' Duracion = "'.$duracion.'" ');
    };
    
    
     
$where = ( !empty($where) ) ? ( ' WHERE ' implode(' AND '$where) ) : '';
     
    
$qry 'SELECT * FROM videos' $where;

$result=mysql_query($qry);
if (
false === $result) {
    echo 
mysql_error();} 
Un poco de luz por favor???Muchisimas gracias a todos!!

Un saludo
  #2 (permalink)  
Antiguo 14/08/2013, 14:27
Avatar de pateketrueke
Modernizr
 
Fecha de Ingreso: abril-2008
Ubicación: Mexihco-Tenochtitlan
Mensajes: 26.399
Antigüedad: 16 años
Puntos: 2534
Respuesta: Filtrar resultados cuando se selecciona ALL en varios select

Podrías tener ambos valores en algún array e iterarlo.

Código PHP:
$conds = array(
  
// <columna>   <indice>
  
'Categoria' => 'categoria',
  
'Duracion' => 'duracion',
  
'Peso' => 'peso',
);

$where = array();

foreach (
$conds as $col => $key) {
  if (! empty(
$_POST[$key]) && ($_POST[$key] !== 'ALL')) {
    
$where []= "{$col} = '{$_POST[$key]}'";
  }

Es sólo un ejemplo que hace la misma comparación lógica, efectivamente te evitas tener que escribir todo a mano, a ver si te sirve.
__________________
Y U NO RTFM? щ(ºдºщ)

No atiendo por MP nada que no sea personal.
  #3 (permalink)  
Antiguo 16/08/2013, 08:37
 
Fecha de Ingreso: agosto-2013
Mensajes: 5
Antigüedad: 10 años, 8 meses
Puntos: 1
Respuesta: Filtrar resultados cuando se selecciona ALL en varios select

Muchas gracias Pateketrueke, al final lo resolvi asi :

Código PHP:

$numero1 
"ALL";
$numero2 "ALL";
$numero3 "ALL";

$numero4 "Color = verde";
$numero5 "Talla = grande";
$numero6 "Precio = 30";


$where = array();

if(
$numero1 != "ALL") {array_push($where,$numero4);};
if(
$numero2 != "ALL") {array_push($where,$numero5);};
if(
$numero3 != "ALL") {array_push($where,$numero6);};

$anuncio implode(' AND '$where);

if(empty(
$where)) {echo "Select * from ropa "; }
else {echo 
"Select * from ropa WHERE ".$anuncio;};
?> 

Última edición por egahedo; 16/08/2013 a las 08:43 Razón: mal el codigo

Etiquetas: select
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 16:41.