MySQL變量包括系統(tǒng)變量和系統(tǒng)變量。這次的學習任務是用戶自定義變量。用戶變量主要包括局部變量和會話變量。
用戶自定義變量的聲明方法形如:@var_name,其中變量名稱由字母、數(shù)字、“.”、“_”和“$”組成。當然,在以字符串或者標識符引用時也可以包含其他字符(例如:@'my-var',@”my-var”,或者@my-var)。
用戶自定義變量是會話級別的變量。其變量的作用域僅限于聲明其的客戶端鏈接。當這個客戶端斷開時,其所有的會話變量將會被釋放。
用戶自定義變量是不區(qū)分大小寫的。
使用SET語句來聲明用戶自定義變量:
SET @my_var = 1;
SET @my_var := 1;
不使用set時采用:=賦值,因為采用=可能被認為是比較操作符。
以下用一個案例說明:
編寫一個 SQL查詢 來實現(xiàn)分數(shù)排名。如果兩個分數(shù)相同,則兩個分數(shù)排名(Rank)應該相同。請注意,平局之后的下一個排名數(shù)應該是下一個連續(xù)的整數(shù)值。換句話說,行列之間不應該有“漏洞”。
+—-+——-+
| Id | Score |
+—-+——-+
| 1 | 3.50 |
| 2 | 3.65 |
| 3 | 4.00 |
| 4 | 3.85 |
| 5 | 4.00 |
| 6 | 3.65 |
+—-+——-+
例如,根據(jù)給定的上述 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表示上一個人的分數(shù)
當與上一個分數(shù)不一樣時@rank = @rank + 1,否則,@rank=rank。
將@rank初始化為1,@pre初始化為-1。
實驗結果為:
以上這篇在MySQL中自定義參數(shù)的使用詳解就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
您可能感興趣的文章:- 關于MySQL的存儲函數(shù)(自定義函數(shù))的定義和使用方法詳解
- 詳解MySql存儲過程參數(shù)的入門使用
- MYSQL配置參數(shù)優(yōu)化詳解