Foros del Web » Programando para Internet » PHP »

Ranking general de votos

Estas en el tema de Ranking general de votos en el foro de PHP en Foros del Web. Hola cracks! Tengo un sistema de votación en mi web. Los usuarios reciben votos y luego se ordenan según un ranking. Cada usuario tiene un ...
  #1 (permalink)  
Antiguo 30/03/2011, 03:31
 
Fecha de Ingreso: agosto-2009
Mensajes: 216
Antigüedad: 13 años, 6 meses
Puntos: 3
Ranking general de votos

Hola cracks!

Tengo un sistema de votación en mi web. Los usuarios reciben votos y luego se ordenan según un ranking. Cada usuario tiene un apartado en su perfil donde puede ver una serie de estadísticas, entre ellas su clasificación en el ranking.

Hasta ahora lo tengo hecho de un modo un poco "burro" y me preguntaba si hay alguna solución más eficiente y mejor. Yo tengo ésto:

Código PHP:
$sql "SELECT *
FROM usuarios
ORDER BY puntos"
;

$res mysql_query($sql);
$contador 1;
while(
$row mysql_fetch_array($res))
{

if(
$row["usuario"] == $user)
{

echo 
$contador;
break;

}else
{

$contador++;

}

Básicamente, recorro todos los registros de la tabla usuario ordenados por puntos y voy contando hasta que llego al del usuario que consulta sus estadísticaas, cuando coinciden, imprimo la posición y listo. Y es que no tengo una tabla con la clasificación general, pues ésta va cambiado a cada instante.

Hay algún método más sencillo y eficiente de hacer ésto??

Gracias!
  #2 (permalink)  
Antiguo 30/03/2011, 05:58
Avatar de abimaelrc
Colaborador
 
Fecha de Ingreso: mayo-2009
Ubicación: En el planeta de Puerto Rico
Mensajes: 14.734
Antigüedad: 13 años, 8 meses
Puntos: 1517
Respuesta: Ranking general de votos

Podrías usar un count para saber el número que representa, algo así
Código MySQL:
Ver original
  1. DROP TABLE IF EXISTS `usuarios`;
  2. CREATE TABLE IF NOT EXISTS `usuarios` (
  3.   `usuarios_id` int(11) unsigned NOT NULL AUTO_INCREMENT,
  4.   `usuario` varchar(100) NOT NULL,
  5.   `puntos` varchar(11) NOT NULL,
  6.   PRIMARY KEY (`usuarios_id`)
  7.  
  8. --
  9. -- Volcar la base de datos para la tabla `usuarios`
  10. --
  11.  
  12. INSERT INTO `usuarios` (`usuarios_id`, `usuario`, `puntos`) VALUES
  13. (1, 'Foo', '15'),
  14. (2, 'Bar', '10'),
  15. (3, 'Baz', '16'),
  16. (4, 'Candy', '15'),
  17. (5, 'Fruits', '17'),
  18. (6, 'Vegetable', '17');

Solo es cuestión de llamar los campos counter y usuario
Código PHP:
Ver original
  1. <?php
  2. /**
  3.  * Conexión a la base de datos
  4.  * ...
  5.  */
  6. $usuario = 2 // o el valor que tengas guardardo, tal vez en un sesión...
  7. $qry = 'SELECT COUNT(*) counter,
  8.        (SELECT usuario
  9.                FROM usuarios
  10.                WHERE usuarios_id = ' . mysql_real_escape_string($usuario) . ') usuario
  11.    FROM usuarios
  12.    WHERE puntos >= (SELECT puntos
  13.                        FROM usuarios
  14.                        WHERE usuarios_id = ' . mysql_real_escape_string($usuario) . ')';
  15. $resource = mysql_query($qry) or die(mysql_error());
  16. $row = mysql_fetch_assoc($resource);
  17. echo $row['counter'] . ' / ' . $row['usuario'];
__________________
Verifica antes de preguntar.
Los verdaderos amigos se hieren con la verdad, para no perderlos con la mentira. - Eugenio Maria de Hostos

Última edición por abimaelrc; 30/03/2011 a las 06:05
  #3 (permalink)  
Antiguo 30/03/2011, 08:34
 
Fecha de Ingreso: agosto-2009
Mensajes: 216
Antigüedad: 13 años, 6 meses
Puntos: 3
Respuesta: Ranking general de votos

Hola abimaelrc,

Gracias por tu respuesta, pero tengo una duda, qué es eso del counter? Es la primera vez que lo veo y no sé cómo funciona.

Gracias!!
  #4 (permalink)  
Antiguo 30/03/2011, 09:58
Avatar de abimaelrc
Colaborador
 
Fecha de Ingreso: mayo-2009
Ubicación: En el planeta de Puerto Rico
Mensajes: 14.734
Antigüedad: 13 años, 8 meses
Puntos: 1517
Respuesta: Ranking general de votos

Verifica en el manual oficial para que te puedas ver como usar cada una de las funciones disponibles para MySQL.
__________________
Verifica antes de preguntar.
Los verdaderos amigos se hieren con la verdad, para no perderlos con la mentira. - Eugenio Maria de Hostos

Etiquetas: general, ranking, votos
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 19:00.