Foros del Web » Programando para Internet » PHP »

ordenar resultados por cantidad de coincidencias

Estas en el tema de ordenar resultados por cantidad de coincidencias en el foro de PHP en Foros del Web. Hola, estaba terminando de probar un buscador de y queria ordenar los resultados de acuerdo a la cantidad de coincidencias. El problema se presenta a ...
  #1 (permalink)  
Antiguo 13/07/2008, 16:29
 
Fecha de Ingreso: agosto-2004
Mensajes: 113
Antigüedad: 19 años, 8 meses
Puntos: 0
ordenar resultados por cantidad de coincidencias

Hola, estaba terminando de probar un buscador de y queria ordenar los resultados de acuerdo a la cantidad de coincidencias.
El problema se presenta a la hora de tomar la cantidad de resultados.
Para el buscador tengo una tabla OPCION con 2 campos (id, opciones) y en otra tabla tengo un campo OPCIONES con los ID separados por comas.
Para el buscador puse tantos check boxs como ID tengo en la tabla OPCION y la idea es que si un usuario marca 4 check box y encuentra resultados con esas 4 opciones los ponga primero y el que tenga 3 segundo y asi sucesivamente.
gracias
  #2 (permalink)  
Antiguo 13/07/2008, 16:37
Avatar de jaronu  
Fecha de Ingreso: febrero-2008
Mensajes: 2.183
Antigüedad: 16 años, 2 meses
Puntos: 52
Respuesta: ordenar resultados por cantidad de coincidencias

Hola

que codigo estas usando?

sera mas facil que alguen de este foro te ayude

Un saludo
  #3 (permalink)  
Antiguo 13/07/2008, 16:48
 
Fecha de Ingreso: agosto-2004
Mensajes: 113
Antigüedad: 19 años, 8 meses
Puntos: 0
Respuesta: ordenar resultados por cantidad de coincidencias

Hola Jaronu, disculpa pero estoy tan confundido que no puse el codigo
checkbox
Código PHP:
<input name="opcion[]" type="checkbox" id="opcion" value="<? echo $id ?>"
<? if (@in_array($id$_GET["opcion"])) echo " checked" ?>>
resultados
Código PHP:
while(list ($key,$val) = @each($_GET["opcion"])) { 
if (isset(
$_GET["opcion"])) ORDER BY id DESC AND servicio LIKE '%,".$val.",%'";

como cuento las opciones marcadas y las agrego al ORDER BY?
gracias
  #4 (permalink)  
Antiguo 13/07/2008, 16:56
Avatar de jaronu  
Fecha de Ingreso: febrero-2008
Mensajes: 2.183
Antigüedad: 16 años, 2 meses
Puntos: 52
Respuesta: ordenar resultados por cantidad de coincidencias

No se pero crero que asi no se hacen las consultas a una BBDD

se usa mysql_query ="la consulta a realizar";
  #5 (permalink)  
Antiguo 13/07/2008, 17:10
 
Fecha de Ingreso: agosto-2004
Mensajes: 113
Antigüedad: 19 años, 8 meses
Puntos: 0
Respuesta: ordenar resultados por cantidad de coincidencias

Jaronu, me parecio que poner la parte del Select from no era necesario porque la duda no la tengo ahi.
Cuando hago el while con las opciones marcadas para obtener los resultados es donde empieza mi duda, ya que quiero contar las opciones marcadas para después hacer el select from y poder ordenar de acuerdo a la cantidad de coincidencias en las opciones marcadas.
Gracias
  #6 (permalink)  
Antiguo 13/07/2008, 17:16
Avatar de jaronu  
Fecha de Ingreso: febrero-2008
Mensajes: 2.183
Antigüedad: 16 años, 2 meses
Puntos: 52
Respuesta: ordenar resultados por cantidad de coincidencias

POr favor, muetsra mas codigo,
  #7 (permalink)  
Antiguo 13/07/2008, 17:37
 
Fecha de Ingreso: agosto-2004
Mensajes: 113
Antigüedad: 19 años, 8 meses
Puntos: 0
Respuesta: ordenar resultados por cantidad de coincidencias

el formulario
Código PHP:
<form name="form1" method="get" action="">
                    Tipo</td>
                        
                          <select name="tipo" style="width:180px" size="1" id="tipo"> 
                        <option value="auto"<? if (@$_GET["tipo"] == "auto") echo " selected"?>>auto</option> 
                        <option value="camioneta"<? if (@$_GET["tipo"] == "camioneta") echo " selected"?>>camioneta</option> 
                      </select>
<?php
$col 
1;
$opcionid 1;
    
$result mysql_query("select id, opcion from opciones");
    while (list(
$id$opcs) = mysql_fetch_array($result)) {
        if (
$col == 1) echo "<tr>\n"?> 
                         
                                      <input name="opcion[]" type="checkbox" id="opcion" value="<? echo $id ?>"
                                <? if (@in_array($id$_GET["servicio"])) echo " checked" ?>><? echo $opcs?>
                             
                          <?php   if ($col == 3) echo "</tr>\n";
        
$col++;
        
$opcionid++;
        if (
$col 3$col 1;
    }
    switch (
$col) {
        case 
1:
            break;
        case 
2:
            echo 
"<td colspan=\"2\" class=\"texto\">&nbsp;</td></tr>\n";
            break;
        case 
3:
            echo 
"<td class=\"texto\">&nbsp;</td></tr>\n";
            break;
    }
            echo 
"<input name=\"opcion0\" type=\"hidden\" id=\"opcion0\" value=\"" . ($opcionid-1) . "\">\n";
?>
<input name="buscar" type="hidden" id="buscar" value="true">
</form>
procesando la busqueda
Código PHP:
<?php
if (isset($_GET["aid"])) {
    
$criterio " ORDER BY id DESC";
} else {
$criterio "";
if (@
$_GET["tipo"] != ""$criterio .= " tipo = '".$_GET["tipo"]."'";
 

while(list (
$key,$val) = @each($_GET["opcion"])) { 
if (isset(
$_GET["opcion"])) $criterio .= " AND opcion LIKE '%,".$val.",%'";
}
}
$orden "";
$tamanopagina $aut_x_pagina;
$rstotal mysql_query("SELECT * FROM automotores WHERE".$criterio);
$npaginas ceil(@mysql_num_rows($rstotal) / $tamanopagina);
if (isset(
$pagina)) {
$paginacion = ($pagina-1)*$tamanopagina;
} else {
$pagina 1;
$paginacion 0;
}
$rs mysql_query("SELECT * FROM automotores WHERE".$criterio.$orden." LIMIT ".$paginacion.",".$tamanopagina);
 
?>
y eso es todo el codigo, omiti el form para la cantidad de resultados por pagina que no viene al caso.
gracias
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:33.