gpt4 book ai didi

php - 回显 while 中 i 的变量

转载 作者:行者123 更新时间:2023-11-29 23:16:30 26 4
gpt4 key购买 nike

我尝试这样的事情:

function userrank($userid){
$sql = mysql_query("SELECT * FROM users ORDER BY atacs DESC");
$i = 1;
while ($row = mysql_fetch_assoc($sql)) {
if ($row['username'] == $userid) {
echo 'You are on ' . $i . ' in the general leaderbord';
}
}
}

在排行榜上它正确地显示了我的排名,但我也想在另一个页面上显示我,在“youraccount”页面上,为此我尝试使用此功能。怎么了?

最佳答案

基本上,您在这里所做的就是计算有多少用户的 atacs 大于或等于 $useridatacs。这样做的问题:

  • 效率极低。请注意,数据库检索并发送到您的while 为每个用户循环一个条目,即使是那些拥有 atacs 的用户小于$userid。除其中一个 while 循环迭代之外的所有迭代设计上什么也不做。浪费大量时间从服务器发送数据数据库到 PHP,它甚至不使用它。
  • 拉回更多数据比必要的。您最终会得到每个用户的每一行您的整个 users 表 - 但您的结果只是一个标量(有多少用户>得分)。
  • 实际上给了你错误的结果如果你的分数与其他人的分数并列。在这种情况下一些得分相同的用户可能会被算作“高于”该用户,其他用户为“低于用户”。

数据库擅长迭代数据;它是 所有“本地”可访问,数据库引擎可以使许多 优化,如果你能用 SQL 描述你想要做什么 完成。所以与其那样做,为什么不直接做 数据库中的所有内容?

set @user_atacs = ( select atacs from users where id = 12 );
select count(*) +1 from users where atacs > @user_atacs;

我在这里模拟了表格:http://sqlfiddle.com/#!2/ff9a86/3

此解决方案本质上只是计算 atacs 高于当前用户的用户数量。所有具有相同分数的用户将获得相同的排名,并且下一个排名将适当更高,因此它不会遭受您的方法的任何错误。

最后一点,做排行榜之类的事情最合适的方法可能是定期预先计算排行榜,然后使用结果来显示每个用户在排行榜中的位置,而不是尝试为每个用户动态计算它。但这远远超出了范围:)

关于php - 回显 while 中 i 的变量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27747659/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com