1. 程式人生 > 實用技巧 >Mysql自定義變數的作用

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 |

查詢語句:

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

注:
@rank表示成績排名
@pre表示上一個人的分數
當與上一個分數不一樣時@rank = @rank + 1,否則,@rank=rank。
將@rank初始化為1,@pre初始化為-1。
結果為:

另:將@i值迴圈自加,進行排名。

1 select @i:=@i+1 as noRow,s.* from student s,(select @i:=0) b