php - SQL 查询构造

标签 php mysql sql

我最近创建了一个评分系统,其中用户按积分降序排列。首先,我曾经将排名存储在自己的列中。我曾经运行这个循环来更新排名:

$i = 1;
    $numberOfRows = mysql_query('SELECT COUNT(`id`) FROM sector0_players');
    $scoreboardquery = mysql_query("SELECT * FROM sector0_players ORDER BY points DESC");
    while(($row = mysql_fetch_assoc($scoreboardquery)) || $i<=$numberOfRows){
        $scoreid = $row['id'];
        $mysql_qeury = mysql_query("UPDATE sector0_players SET scoreboard_rank = '$i' WHERE id = '$scoreid'");
    $i++;
    }

这真的很困难,更不用说在大量用户上实际运行它的速度很慢。 相反,我尝试构建一个查询并最终得到这个结果。

SET @rownum := 0;
SELECT scoreboard_rank, id, points
FROM (
SELECT @rownum := @rownum + 1 AS scoreboard_rank, id, points FROM sector0_players ORDER BY points DESC
)
as result WHERE id = '1';

但是,这只是一条 select 语句。无论如何,我可以绕过它并更改它,以便它像循环一样更新表吗?

最佳答案

请尝试使用以下查询:

set @rownum:=0;
update sector0_players set scoreboard_rank=@rownum:=@rownum+1 ORDER BY points DESC;

PHP 代码可以是,

mysql_query("set @rownum:=0;");
mysql_query("update sector0_players set scoreboard_rank=@rownum:=@rownum+1 ORDER BY points DESC;");

关于php - SQL 查询构造,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10185968/

相关文章:

php - 包含数据库中值的下拉菜单

mysql - Longtext 会减慢对其他字段的查询吗?

mysql - 在sql存储过程中使用两个IF THEN

mysql - 简单的 SELECT 过程

sql - PATINDEX 和 SUBSTRING 没有返回正确的值

php - 向表列添加标题,并从 SQL 输出总计

javascript - 我如何将按钮放在文本区域内并限制文本区域的大小?

php - 使 MySQL 查询动态化的最佳方法(例如,更新查询参数以显示前一周)

php - 将纯 PHP 代码转换为 codeigniter

sql - 我怎样才能从字符串中获取reqnum?