关于mysql 自定义@row的使用

本文介绍了一种在数据库查询中实现成绩和积分排名的方法。对于成绩排名,相同分数的人员名次相同;对于积分排名,则根据积分及更新时间进行排序。文章解决了排名显示为double类型的问题,并提供SQL实现案例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  • 应用场景:在对成绩或者积分排名时,往往需要显示排名;

    • 成绩排名:相同分数的人,名次相同

      Select s.Score,
          case 
            when @rowtotal = s.Score then cast(@rownum as SIGNED  INTEGER) # 当这个成绩和@rowtotal上一次的成绩相同时,@rownum不变
            when @rowtotal := s.Score then cast(@rownum :=@rownum +1 as SIGNED  INTEGER) # 当取到的成绩和上一次成绩不同时, @rownum +1 ,rank排名加一
            when @rowtotal = 0 then cast(@rownum :=@rownum +1 as SIGNED  INTEGER) # 当取到的成绩为0时,排名+1
          end as Rank 
      from 
      (select Id,Score from Scores order by Score desc)s, # 通过分数倒序排列成绩
      (Select @rownum :=0,@rowtotal :=null) r   #这个是关键,@rownum,@rowtotal先置空,然后和上边的成绩关联
    • 积分排名:按积分插入时间排名

      SELECT
          obj.score,@rownum := @rownum + 1 AS Rank
      FROM
          (
              SELECT
                  user_id,
                  score
              FROM
                  `sql_rank`
              ORDER BY
                  score DESC,
                  update_time ASC
          ) AS obj,
          (SELECT @rownum := 0) r

      我遇到的问题是,排名显示的是1.0,2.0的double类型,所以我用cast(@rownum as SIGNED INTEGER)转化了一下

转载于:https://www.cnblogs.com/lisongyu/p/10135380.html

MySQL 自定义变量是一种用户可以创建的变量,用于存储任意类型的值,例如数字、字符串和日期等。它可以在 MySQL 会话中使用,以便在查询中引用该变量的值,也可以在存储过程、函数、触发器等数据库对象中使用。以下是 MySQL 自定义变量的一些常见用法: 1. 定义变量:使用 SET 关键字定义变量并赋值,例如: ``` SET @myVar = 'Hello World'; ``` 2. 引用变量:在查询中使用 @ 符号引用变量,例如: ``` SELECT @myVar; ``` 3. 修改变量:使用 SET 关键字修改变量的值,例如: ``` SET @myVar = 'Hello MySQL'; ``` 4. 计算变量:可以在查询中使用自定义变量进行计算,例如: ``` SET @num1 = 10; SET @num2 = 5; SELECT @num1 + @num2; ``` 5. 使用变量作为查询条件:可以在 WHERE 子句中使用自定义变量作为查询条件,例如: ``` SET @name = 'John'; SELECT * FROM users WHERE name = @name; ``` 6. 在存储过程中使用变量:可以在存储过程中定义和使用自定义变量,例如: ``` DELIMITER // CREATE PROCEDURE myProcedure() BEGIN DECLARE myVar INT; SET myVar = 100; SELECT myVar; END // DELIMITER ; ``` 7. 在触发器中使用变量:可以在触发器中定义和使用自定义变量,例如: ``` DELIMITER // CREATE TRIGGER myTrigger BEFORE INSERT ON myTable FOR EACH ROW BEGIN DECLARE myVar VARCHAR(50); SET myVar = NEW.name; INSERT INTO log_table VALUES(myVar); END // DELIMITER ; ``` 总之,MySQL 自定义变量可以帮助用户在查询和数据库对象中存储和引用数据,提高查询和处理效率。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值