Foros del Web » Programando para Internet » PHP »

Como puedo ordenar los resultados de una consulta

Estas en el tema de Como puedo ordenar los resultados de una consulta en el foro de PHP en Foros del Web. Hola Tengo una consulta a una base de datos de la que necesito ordenar los resultados de una forma especial. En principio uso mysql_fetch_array ($IdConsulta) ...
  #1 (permalink)  
Antiguo 11/10/2004, 03:55
 
Fecha de Ingreso: febrero-2004
Ubicación: Asturias
Mensajes: 171
Antigüedad: 13 años, 10 meses
Puntos: 0
Como puedo ordenar los resultados de una consulta

Hola

Tengo una consulta a una base de datos de la que necesito ordenar los resultados de una forma especial. En principio uso mysql_fetch_array ($IdConsulta) y el resultado me sale en array tipo tabla, pero quiero que me salga de otra forma.
La consulta la consigo representar con foreach, pero no es exactamente lo que quiero.

Código PHP:
require_once('../Connections/Astur.php');
if (isset(
$_GET['fil'])) {
  
$colname_Recordset0 = (get_magic_quotes_gpc()) ? $_GET['fil'] : addslashes($_GET['fil']);
}
mysql_select_db($database_Astur$Astur);
$Query sprintf("SELECT DISTINCTROW Filum, Clase, Orden, Familia, Genero FROM astur WHERE Filum = '%s' ORDER BY Genero ASC"$colname_Recordset0);
$IdConsulta mysql_query($Query$Astur) or die(mysql_error());
echo 
$_GET['fil']; echo "<br>";

$NFilas mysql_num_rows($IdConsulta);
echo 
"Hay ".$NFilas." filas devueltas en la consulta<P>";
echo 
"<table border="1" width="50%" cellpadding="2">";
echo 
"<tr>";
echo 
"<td>Filum</td>";
echo 
"<td>Clase</td>";
echo 
"<td>Orden</td>";
echo 
"<td>Familia</td>";
echo 
"<td>Genero</td>";
echo 
"</tr>";
while(
$v=mysql_fetch_array ($IdConsulta)){ 

foreach(
$v as $clave=>$valor) { 
 if(!
is_int($clave)){ 
     echo 
"<td>".$valor."</td>";
     }  
}echo 
"</tr>";
 } 
echo 
"</table>";
mysql_free_result($IdConsulta); 
En http://www.asturnatura.com/duda/taxo_php.htm teneis la tabla de salida que tengo y debajo la forma en que quiero representar estos resultados.

Gracias
  #2 (permalink)  
Antiguo 13/10/2004, 03:23
 
Fecha de Ingreso: febrero-2004
Ubicación: Asturias
Mensajes: 171
Antigüedad: 13 años, 10 meses
Puntos: 0
hola a todos:

he estado mirando el problema y he visto en

http://www.forosdelweb.com/s8929f72e...msg182614.html

que Lio Tse se quedo donde yo. es buena solucion la que aporta, pero no paso tampoco de ahi. Se trata de reordenar el array, como el dice
  #3 (permalink)  
Antiguo 13/10/2004, 04:35
Ex Colaborador
 
Fecha de Ingreso: junio-2002
Mensajes: 9.091
Antigüedad: 15 años, 5 meses
Puntos: 16
Hola,

El metodo que uso yo es el de "recordar" cual ha sido el ultimo valor mostrado y solo mostrar si es distinto. En tu caso, tendria cuatro valores que recordar: filum, clase, orden y familia. Para cada registro, si el valor para ese registro es distinto que el ultimo mostrado, pues muestro el nuevo valor y lo "recuerdo". Algo como:
Código PHP:
// inicalizamos la "memoria"
$ult_filum='';
$ult_clase='';
$ult_orden='';
$ult_familia='';
while(
$v=mysql_fetch_array ($IdConsulta)){
  
// mostramos el filum?
  
if ($ult_filum!=$v['Filum']) {
    echo 
$v['Filum'].'<br>';
    
$ult_filum=$v['Filum'];
  }
  
// mostramos la clase?
  
if ($ult_clase!=$v['Clase']) {
    echo 
'&nbsp;&nbsp'.$v['Clase].'<br>';
    $ult_clase=$v['
Clase'];
  }
  // mostramos el orden?
  if ($ult_orden!=$v['
Orden']) {
    echo '
&nbsp;&nbsp&nbsp;&nbsp'.$v['Orden'].'<br>';
    $ult_orden=$v['
Orden'];
  }
  // mostramos la familia?
  if ($ult_familia!=$v['
Familia']) {
    echo '
&nbsp;&nbsp&nbsp;&nbsp&nbsp;&nbsp'.$v['Familia].'<br>';
    
$ult_familia=$v['Familia'];
  }

Para que esto funcione, la consulta tiene que devilver los valores en el orden que muestras en tu pagina.

Saludos.
__________________
Josemi

Aprendiz de mucho, maestro de poco.
  #4 (permalink)  
Antiguo 13/10/2004, 04:49
 
Fecha de Ingreso: febrero-2004
Ubicación: Asturias
Mensajes: 171
Antigüedad: 13 años, 10 meses
Puntos: 0
Gracias josemi, vaya forma de romperme la cabeza con lo sencillo que era al final
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:01.