mysql 分数排名,更新表

本文介绍如何使用MySQL进行数据排名查询,并将排名结果更新至表中。通过使用变量和子查询,实现对e_Task_Result表中数据按分数排序并添加排名。

如何用mysql 查询出数据出数据排名,然后加编号;


表字段说明:查询e_Task_Result表 ,score代表分数,task_result_id 代表id

SELECT
               (@rowNO := @rowNo+1) AS rowno,
               task_result_id ,score FROM (
(SELECT task_result_id ,score FROM e_task_result   ORDER BY score DESC) a,(SELECT @rowNo :=0) b )  


如何将查询出来的排名更新到表中

表字段说明:查询e_Task_Result表 ,score代表分数,task_result_id 代表id,rank代表排名

UPDATE e_task_result d
  LEFT JOIN (SELECT
               (@rowNO := @rowNo+1) AS rowno,
               task_result_id
             FROM (SELECT
                     task_result_id
                   FROM e_task_result etr
                   ORDER BY task_result_status DESC,etr.score DESC,end_date) a,
               (SELECT
                  @rowNO             :=0) b) c
    ON c.task_Result_id = d.task_result_id
SET d.rank = rowno



MySQL触发器是一种特殊的存储过程,它们会在特定数据库操作(如INSERT、UPDATE或DELETE)发生时自动执行。如果你想在给定中实施一种规则,比如对得分相同的记录进行排序,可以创建一个触发器来处理这种情况。 当你有两张,一张是成绩(score_table),另一张是用户信息(user_table),并且你希望在添加新成绩或者更新已有成绩时,如果分数相同,则按照另一个字段(如用户ID或其他自定义规则)进行并列排序,你可以这样做: 1. 首先,创建一个触发器,例如在score_table上: ```sql CREATE TRIGGER rank_scores AFTER INSERT ON score_table FOR EACH ROW BEGIN UPDATE score_table SET user_rank = ( SELECT COUNT(*) + 1 FROM score_table AS T2 WHERE T2.score = NEW.score AND (T2.user_id IS NULL OR T2.user_id > NEW.user_id) ) WHERE score = NEW.score; END; ``` 这里假设`user_rank`是你想要添加的新字段,示用户的并列排名。当插入新的分数时,触发器会检查是否有其他用户得同样分,并计算出当前新行应该排在这些分数中的位置。 2. 如果你想同时考虑所有更新操作,可以替换`AFTER INSERT`为`AFTER INSERT OR UPDATE`。 注意,这个触发器只是一个基本示例,实际应用可能需要更复杂的逻辑来处理并发问题和数据一致性。此外,这种实时计算排名的方式可能会对性能产生影响,特别是在大数据集下,所以你需要权衡其利弊。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值