Ir para conteúdo
  • Cadastre-se

Website [Ajuda] Nesse codigo php para mostra ranking


Posts Recomendados

 

Galera tem como me ajudar a montar um ranking na home do site, para mostrar os top 5 Kages que mais tem pontos.

 Obs: semelhante ao do print abaixo.

 

Tenho como referencia esse código php, onde mostra quantos "pontos " tem a guild..

 obs: na tabela 'players' tem outra tebela 'graduacao_points', marcando a quantidade depontos dos jogadores.

 

$ots = POT::getInstance();

$ots->connect(POT::DB_MYSQL, connection());

$SQL = $ots->getDBHandle();

 

echo'<div class="message"><div class="title">Top Guild Points</div> <div class="content">

                   

<table border="0" cellspacing="3" cellpadding="4" width="100%">

    <tr>';

$i = 0;

foreach($SQL->query('

        SELECT

            `g`.`id` AS `id`,

            `g`.`name` AS `name`,

            SUM(`p`.`level`) AS `level`,

            COUNT(`p`.`name`) AS `count`,

            AVG(`p`.`level`) AS `average`,

            MIN(`p`.`level`) AS `min`,

            MAX(`p`.`level`) AS `max`

        FROM `players` p

            LEFT JOIN `guild_ranks` gr ON `p`.`rank_id` = `gr`.`id`

            LEFT JOIN `guilds` g ON `gr`.`guild_id` = `g`.`id`

        WHERE `g`.`id` = `g`.`id`

        GROUP BY `name`

        ORDER BY `level` DESC

        LIMIT 3

    ') as $guild)

    {

        $Points = $guild['level'] + $guild['count'] + round($guild['average']) + $guild['min'] + $guild['max'];

        echo '

             <td style="padding-right:20px;padding-top:3px" align="center">

                Top Rating :

        <p style="color:#336600;display:inline;padding: 0 0 3px 0;font-weight: bold;">'.$Points.'</p>

                <a href="'.WEBSITE.'/index.php/guilds/view/' . $guild['id'] . '"><img src="'.WEBSITE.'/public/images/gp/'. $i = $i + 1 .'.png" width="60" height="60" border="0"/>

                <br /><b>' . $guild['name'] . '</b></a><br />

            </td>';

    }

echo'   </tr>

</table>';

    if(empty($i)) {

        echo "<center><font color='red'>There is no guilds yet.</font></center>";

    }

echo "</div>";

echo "</div><br/>";

?>

 

 

Print anexado:

 

Screenshot_257.png

Link para o post
Compartilhar em outros sites
  • 2 weeks later...
  • Respostas 30
  • Created
  • Última resposta

Top Posters In This Topic

<?php
$ots = POT::getInstance();
$ots->connect(POT::DB_MYSQL, connection());
$SQL = $ots->getDBHandle();

echo '<div class="message"><div class="title">Top 5 Kages - Pontuação</div><div class="content">
    <table border="0" cellspacing="3" cellpadding="4" width="100%">
        <tr>';

// Consulta SQL para obter os top 5 Kages com base nos pontos
$query = '
    SELECT
        `p`.`name` AS `name`,
        `p`.`points` AS `points`
    FROM `players` p
    ORDER BY `points` DESC
    LIMIT 5
';

$result = $SQL->query($query);
$i = 1;

while ($row = $result->fetch()) {
    $kageName = $row['name'];
    $kagePoints = $row['points'];

    echo '
        <td style="padding-right: 20px; padding-top: 3px;" align="center">
            <p style="color: #336600; display: inline; padding: 0 0 3px 0; font-weight: bold;">' . $kagePoints . '</p>
            <br /><b>' . $i . '. ' . $kageName . '</b>
        </td>';

    $i++;
}

echo '
        </tr>
    </table>';

if ($i === 1) {
    echo "<center><font color='red'>Não há Kages registrados.</font></center>";
}

echo '</div></div><br/>';
?>

tente ai se ve erro me fala aqui

Editado por sverkoa
editei e atualizei (veja o histórico de edições)
Link para o post
Compartilhar em outros sites
  Em 09/06/2023 em 20:11, sverkoa disse:
<?php

$ots = POT::getInstance();
$ots->connect(POT::DB_MYSQL, connection());
$SQL = $ots->getDBHandle();

echo '<div class="message"><div class="title">Top Guild Points</div> <div class="content">

<table border="0" cellspacing="3" cellpadding="4" width="100%">
    <tr>';

$i = 0;

foreach ($SQL->query('
        SELECT
            `g`.`id` AS `id`,
            `g`.`name` AS `name`,
            SUM(`p`.`level`) AS `level`,
            COUNT(`p`.`name`) AS `count`,
            AVG(`p`.`level`) AS `average`,
            MIN(`p`.`level`) AS `min`,
            MAX(`p`.`level`) AS `max`
        FROM `players` p
            LEFT JOIN `guild_ranks` gr ON `p`.`rank_id` = `gr`.`id`
            LEFT JOIN `guilds` g ON `gr`.`guild_id` = `g`.`id`
        WHERE `g`.`id` = `g`.`id`
        GROUP BY `name`
        ORDER BY `level` DESC
        LIMIT 3
    ') as $guild) {
    $Points = $guild['level'] + $guild['count'] + round($guild['average']) + $guild['min'] + $guild['max'];

    echo '
        <td style="padding-right:20px;padding-top:3px" align="center">
            Top Rating :
            <p style="color:#336600;display:inline;padding: 0 0 3px 0;font-weight: bold;">' . $Points . '</p>
            <a href="' . WEBSITE . '/index.php/guilds/view/' . $guild['id'] . '">
                <img src="' . WEBSITE . '/public/images/gp/' . ($i = $i + 1) . '.png" width="60" height="60" border="0"/>
                <br /><b>' . $guild['name'] . '</b>
            </a><br />
        </td>';
}

echo '   </tr>
</table>';

if (empty($i)) {
    echo "<center><font color='red'>There are no guilds yet.</font></center>";
}

echo "</div>";
echo "</div><br/>";
?>

tente ai se ve erro me fala aqui

Mostrar mais  

amigo, nao notei diferença.. ainda ta mostrando os "pontos" das guilds..

 era pra monstrar a  'graduacao_points' dos players

print de como esta:

https://imgur.com/a/RW4ZQAr

Link para o post
Compartilhar em outros sites

n deu certo

  Em 09/06/2023 em 20:11, sverkoa disse:
<?php

$ots = POT::getInstance();
$ots->connect(POT::DB_MYSQL, connection());
$SQL = $ots->getDBHandle();

echo '<div class="message"><div class="title">Top Guild Points</div> <div class="content">

<table border="0" cellspacing="3" cellpadding="4" width="100%">
    <tr>';

$i = 0;

foreach ($SQL->query('
        SELECT
            `g`.`id` AS `id`,
            `g`.`name` AS `name`,
            SUM(`p`.`level`) AS `level`,
            COUNT(`p`.`name`) AS `count`,
            AVG(`p`.`level`) AS `average`,
            MIN(`p`.`level`) AS `min`,
            MAX(`p`.`level`) AS `max`
        FROM `players` p
            LEFT JOIN `guild_ranks` gr ON `p`.`rank_id` = `gr`.`id`
            LEFT JOIN `guilds` g ON `gr`.`guild_id` = `g`.`id`
        WHERE `g`.`id` = `g`.`id`
        GROUP BY `name`
        ORDER BY `level` DESC
        LIMIT 3
    ') as $guild) {
    $Points = $guild['level'] + $guild['count'] + round($guild['average']) + $guild['min'] + $guild['max'];

    echo '
        <td style="padding-right:20px;padding-top:3px" align="center">
            Top Rating :
            <p style="color:#336600;display:inline;padding: 0 0 3px 0;font-weight: bold;">' . $Points . '</p>
            <a href="' . WEBSITE . '/index.php/guilds/view/' . $guild['id'] . '">
                <img src="' . WEBSITE . '/public/images/gp/' . ($i = $i + 1) . '.png" width="60" height="60" border="0"/>
                <br /><b>' . $guild['name'] . '</b>
            </a><br />
        </td>';
}

echo '   </tr>
</table>';

if (empty($i)) {
    echo "<center><font color='red'>There are no guilds yet.</font></center>";
}

echo "</div>";
echo "</div><br/>";
?>

tente ai se ve erro me fala aqui

Expand   Mostrar mais  

n deu certo, continua mostrando as guilds 

Link para o post
Compartilhar em outros sites

Participe da conversa

Você pode postar agora e se cadastrar mais tarde. Se você tem uma conta, faça o login para postar com sua conta.

Visitante
Responder

×   Você colou conteúdo com formatação.   Remover formatação

  Apenas 75 emojis são permitidos.

×   Seu link foi automaticamente incorporado.   Mostrar como link

×   Seu conteúdo anterior foi restaurado.   Limpar o editor

×   Não é possível colar imagens diretamente. Carregar ou inserir imagens do URL.

  • Quem Está Navegando   0 membros estão online

    Nenhum usuário registrado visualizando esta página.

  • Conteúdo Similar

    • Por Andersontatuador
      .Qual servidor ou website você utiliza como base? 
      Global Full 8.60 + Zao
      Qual o motivo deste tópico? 
      O site não esta adicionando os pontos na conta dos plays.
       
      Está surgindo algum erro? Se sim coloque-o aqui. 
       
      Você tem o código disponível? Se tiver publique-o aqui: 
         
      Você tem alguma imagem que possa auxiliar no problema? Se sim, coloque-a aqui. 
       



    • Por A.Mokk
      .Qual servidor ou website você utiliza como base? 
      TFS 0.4
      Qual o motivo deste tópico? 
      Estou tendo um probleminha indelicado no meu site, gostaria de obter respostas aqui com voces que sao sempre muito eficientes e praticos.
      Está surgindo algum erro? Se sim coloque-o aqui. 
       
       
    • Por thunmin
      .Qual servidor ou website você utiliza como base? 
      Canary
      Qual o motivo deste tópico? 
      Não consigo deixar ele automatico os players tem que confirmar o pagamento depois eu tenho que verificar se caiu pra depois eu confirmar e colocar as coins
      Está surgindo algum erro? Se sim coloque-o aqui. 
       
      Você tem o código disponível? Se tiver publique-o aqui: 
         
      Você tem alguma imagem que possa auxiliar no problema? Se sim, coloque-a aqui. 
       
    • Por Jordan422
      Faala Deuses do Tibia! Estou com um projeto sólido de um global old, mas to preso nessa parte do website viu.. Eu dou meu jeitinho mas ta chegando nas coisas avançadas que precisa daquele freelancer bacana para ajeitar umas páginas para mim! Já tenho as ideias, basta somente botar a mão na massa.. Quem estiver interessado por favor entrar em contato por mensagem aqui no Tibiaking mesmo ou preferencialmente pelo discord mythh9257 
       
    • Por moleza
      Para quem quer abrir um servidor antigo que roda em php5 e está com dificuldade com a configuração do linux, pode contratar um cpanel que contenha o php5 que facilita a configuração do site!!
       
      essa foi a minha solução!
       
      Resolvido !!
  • Estatísticas dos Fóruns

    96844
    Tópicos
    519608
    Posts



×
×
  • Criar Novo...

Informação Importante

Confirmação de Termo