在MySQL中自定义参数的使用详解

作者:长弓Smile 时间:2024-01-22 22:30:31 

MySQL变量包括系统变量和系统变量。这次的学习任务是用户自定义变量。用户变量主要包括局部变量和会话变量。

用户自定义变量的声明方法形如:@var_name,其中变量名称由字母、数字、“.”、“_”和“$”组成。当然,在以字符串或者标识符引用时也可以包含其他字符(例如:@'my-var',@”my-var”,或者@my-var)。

用户自定义变量是会话级别的变量。其变量的作用域仅限于声明其的客户端链接。当这个客户端断开时,其所有的会话变量将会被释放。

用户自定义变量是不区分大小写的。

使用SET语句来声明用户自定义变量:


SET @my_var = 1;
SET @my_var := 1;

不使用set时采用:=赋值,因为采用=可能被认为是比较操作符。

以下用一个案例说明:

编写一个 SQL查询 来实现分数排名。如果两个分数相同,则两个分数排名(Rank)应该相同。请注意,平局之后的下一个排名数应该是下一个连续的整数值。换句话说,行列之间不应该有“漏洞”。

+—-+——-+
| Id | Score |
+—-+——-+
| 1 | 3.50 |
| 2 | 3.65 |
| 3 | 4.00 |
| 4 | 3.85 |
| 5 | 4.00 |
| 6 | 3.65 |
+—-+——-+

例如,根据给定的上述 Scores 表,您的查询应该生成以下报告(按最高分排序):

+——-+——+
| Score | Rank |
+——-+——+
| 4.00 | 1 |
| 4.00 | 1 |
| 3.85 | 2 |
| 3.65 | 3 |
| 3.65 | 3 |
| 3.50 | 4 |
+——-+——+

查询语句:


select Score, @rank := @rank + (@pre <> (@pre:=Score)) Rank
from Scores ,(SELECT @rank := 0,@pre:= -1) INIT
ORDER BY Score DESC

注:

@rank表示成绩排名

@pre表示上一个人的分数

当与上一个分数不一样时@rank = @rank + 1,否则,@rank=rank。

将@rank初始化为1,@pre初始化为-1。

实验结果为:

在MySQL中自定义参数的使用详解

来源:https://blog.csdn.net/u012485480/article/details/79586895

标签:MySQL,自定义,参数
0
投稿

猜你喜欢

  • 通用SQL存储过程分页以及asp.net后台调用的方法

    2024-01-29 05:03:58
  • 基于python的图片修复程序(实现水印去除)

    2021-07-03 13:35:04
  • Linux自动备份MySQL数据库脚本代码

    2024-01-24 05:00:12
  • Mysql实现企业级日志管理、备份与恢复的实战教程

    2024-01-13 16:30:16
  • 使用auto.js实现自动化每日打卡功能

    2024-04-16 08:47:38
  • 让python 3支持mysqldb的解决方法

    2024-01-15 22:50:08
  • ASP连接11种数据库语法总结

    2007-09-29 12:07:00
  • python删除字符串中指定字符的方法

    2022-12-02 18:32:44
  • matplotlib绘制甘特图的万能模板案例

    2022-07-11 20:24:08
  • python中二分查找法的实现方法

    2023-02-02 16:19:16
  • python实现电子词典

    2021-12-19 08:29:03
  • 最新的关键SQL Server漏洞已被微软证实

    2009-03-16 14:31:00
  • Go1.18新特性对泛型支持详解

    2024-05-22 17:46:25
  • 关于Pytorch的MLP模块实现方式

    2021-12-19 03:28:22
  • 使用Python的Treq on Twisted来进行HTTP压力测试

    2023-01-26 22:29:28
  • React路由鉴权的实现方法

    2024-05-02 17:06:12
  • SQL Server获取磁盘空间使用情况

    2024-01-21 17:30:43
  • python中PS 图像调整算法原理之亮度调整

    2021-02-09 17:51:01
  • Oracle 查询存储过程做横向报表的方法

    2024-01-16 00:59:55
  • python实现单张图像拼接与批量图片拼接

    2023-07-28 12:33:36
  • asp之家 网络编程 m.aspxhome.com