mysql自定义变量

本文探讨MySQL中全局变量、会话变量、局部变量及自定义变量的区别,并通过LeetCode178题实例,展示如何使用自定义变量实现dense_rank()功能,完成分数排名的计算。

mysql变量种类:全局变量/会话变量/局部变量/自定义变量

参考:https://www.cnblogs.com/genialx/p/5932558.html

 

自定义变量能让sql实现更复杂的功能

例子:LeetCode178 https://leetcode-cn.com/problems/rank-scores/ 分数排名实现dense_rank()功能

select 
s.Score, a.r as 'Rank'
from Scores s 
join (select Score, @row:=@row+1 as r from 
(select distinct Score from Scores order by Score desc) c,
(select @row:=0) t) a
on s.Score = a.Score
order by s.Score desc

参考:https://www.cnblogs.com/guaidaodark/p/6037040.html 写的比较全了

 

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值