Foros del Web » Programando para Internet » PHP »

Ordenar según contador PHP + MySQL

Estas en el tema de Ordenar según contador PHP + MySQL en el foro de PHP en Foros del Web. Hola, tengo un contador muy simple. Sería muy largo de contar el funcionamiento de todo el script, pero básicamente se trata de un top de ...
  #1 (permalink)  
Antiguo 21/02/2011, 13:12
 
Fecha de Ingreso: febrero-2009
Mensajes: 202
Antigüedad: 15 años, 2 meses
Puntos: 3
Ordenar según contador PHP + MySQL

Hola,
tengo un contador muy simple. Sería muy largo de contar el funcionamiento de todo el script, pero básicamente se trata de un top de las páginas más visitadas en mi web. Cuando alguien visita una de mis páginas hay un script que se encarga de agregar en una tabla la IP y un id asociado a la página visitada. Ahora lo que quiero es mostrar el top, pero mi ciclo while me devuelve esto:

Cita:
Las páginas más visitadas:
Pagina id 1 visitada 5 veces
Pagina id 2 visitada 80 veces
Pagina id 3 visitada 2 veces
Ya que mi ciclo while hace el recorrido según la cantidad de ids de paginas y en cada uno de esos recorridos registra el mysql_num_rows para determinar cuantas veces ha sido visitada. Yo quiero que eso esté ordenado, es decir:

Cita:
Las páginas más visitadas:
Pagina id2 visitada 80 veces
Pagina id 1 visitada 5 veces
Pagina id 3 visitada 2 veces
No se me ocurre como hacerlo. A ver si pueden darme una manito :)

Gracias!
  #2 (permalink)  
Antiguo 21/02/2011, 13:14
Avatar de AdrianSeg  
Fecha de Ingreso: enero-2010
Mensajes: 595
Antigüedad: 14 años, 3 meses
Puntos: 14
Respuesta: Ordenar según contador PHP + MySQL

Usa en la sentencia ORDER BY idsspagina DESC...si nos pegas esa parte del codigo podremos ayudarte mejor.
  #3 (permalink)  
Antiguo 21/02/2011, 13:34
 
Fecha de Ingreso: febrero-2009
Mensajes: 202
Antigüedad: 15 años, 2 meses
Puntos: 3
Respuesta: Ordenar según contador PHP + MySQL

Claro el tema es que yo quiero que se ordene según a la cantidad de resultados de la consulta, no al numero de id de la página. Te algo de código:

PAGINA QUE REGISTRA LA VISITA:
Código:
$id= id de la pagina que esta visitando;
$query=mysql_query("INSERT INTO visitas VALUES ('','$id'//(esto es paginaid en la tabla)//,'$ip')");
PAGINA QUE CUENTA VISITAS:
Código:
$busco_paginas=mysql_query("SELECT * FROM paginas");
$cuento_paginas=mysql_num_rows($busco_paginas); //Cantidad de páginas para hacer el ciclo
$x= 1;
echo "<ol>";
while($x<=$cuento_paginas){
$busco_resumen=mysql_query("SELECT * FROM resumen WHERE paginaid='$x'") or die (mysql_error());
$cuento_resumen=mysql_num_rows($busco_resumen);
echo "<li>En la paginaid $x la cantidad de visitas es $cuento_resumen</li>";
$x++;
}
echo "</ol>";
Gracias!
  #4 (permalink)  
Antiguo 21/02/2011, 13:47
 
Fecha de Ingreso: diciembre-2010
Mensajes: 788
Antigüedad: 13 años, 4 meses
Puntos: 51
Respuesta: Ordenar según contador PHP + MySQL

Eso lo tenés que hacer con una sola consulta.

Por ejemplo ( sin probar ):

Código SQL:
Ver original
  1. SELECT COUNT(id) AS cpag FROM resumen GROUP BY paginaid  ORDER BY cpag
  #5 (permalink)  
Antiguo 21/02/2011, 13:54
 
Fecha de Ingreso: febrero-2009
Mensajes: 202
Antigüedad: 15 años, 2 meses
Puntos: 3
Respuesta: Ordenar según contador PHP + MySQL

Mmmm no entiendo esa consulta, la probé y me da "You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'paginaid ORDER BY cpag' at line 1"
¿Me podés explicar que es eso de count(id) AS cpag y GROUP BY paginaid y cómo imprimiría un resultado de esa consulta para mostrar el top?

Gracias!
  #6 (permalink)  
Antiguo 21/02/2011, 14:08
 
Fecha de Ingreso: diciembre-2010
Mensajes: 788
Antigüedad: 13 años, 4 meses
Puntos: 51
Respuesta: Ordenar según contador PHP + MySQL

Pasado a seudocódigo sería algo así:

Seleccionar cantidad de id ( campo id de tabla resumen ) con el alias cpag, desde la tabla resumen, agrupados por paginaid, ordenados por cpag ( alias del contador ).

Esto te traería ( probalo en el phpmyadmin para verlo ), registros con la única columna "cpag", ordenado por cpag ( se me paso poner DESC, para que sea descendente ).

Código SQL:
Ver original
  1. SELECT *, COUNT(id) AS cpag FROM resumen GROUP BY paginaid ORDER BY cpag DESC

La idea era orientarte, ya que no se como es la estructura de tu base de datos.

Si querés contar las visitas solamente, y estas están en la tabla "visitas". Haces algo así:

Código SQL:
Ver original
  1. SELECT COUNT(id) AS cpag FROM visitas GROUP BY paginaid  ORDER BY cpag DESC

Siempre y cuando tengas un campo id y otro paginaid en esa tabla.

Etiquetas: contador, mysql
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 02:39.