mysql用戶變量和set語句

1 用戶變量介紹
    用戶變量即用戶自己定義的變量,我們可以給用戶變量分配值,並且可用在任何可以正常使用標量表達式的地方。
    引入用戶變量之前我們必須使用set語句或select語句來定義它,然後爲它賦一個值,否則變量就只有一個空值。
    用戶變量與連接有關。也就是說,一個客戶端定義的變量不能被其它客戶端看到或使用。當客戶端退出時,該客戶端連接的所有變量將自動釋放。
2 用戶變量定義
    set語句可用於向系統變量或用戶變量賦值,針對用戶變量的定義如下:
SET @var_name = expr [, @var_name = expr] ...
    也可使用select語句來定義:
SELECT @var_name := expr [, @var_name = expr] ...
    用戶變量:以"@"開始,形式爲"@var_name",以區分用戶變量及列名。它可以是任何隨機的,複合的標量表達式,只要其中沒有列指定。
    一個變量名可以由當前字符集的數字字母字符和“_”、“$”和“.”組成。缺省字符集是ISO-8859-1 Latin1;這可以用mysqld 的--default-character-set 選項更改字符集。
    對於SET,可以使用=或:=來賦值,對於SELECT只能使用:=來賦值。
    我們可以使用一條簡單的select語句查詢定義的用戶變量的值。
3 用戶變量的使用

    3.1 通過set的實例
    用來把一個值賦給一個變量的標量表達式可以是複合表達式。計算,函數,系統標量以及其他用戶變量都是允許的,子查詢也是允許的。然後通過select語句可以獲取一個用戶變量的值,結果是帶有一行的一個表。

mysql> set @var1=1, @var2='vartest', @var3=abs(-2), @var4=(select count(*) from mysql.user);
mysql> select @var1, @var2, @var3, @var4;
+-------+---------+-------+-------+
| @var1 | @var2   | @var3 | @var4 |
+-------+---------+-------+-------+
|     1 | vartest |     2 |    25 |
+-------+---------+-------+-------+
    在用來爲一個用戶變量賦值的表達式中,也可以指定其它的用戶變量,需要注意的是mysql首先確定所有表達式的值,之後纔會把值賦給變量。
    例如:
mysql> set @varA = 2; 
    對於下面兩個例子,varB的值是不同的。
    例1:
mysql> set @varA = 3, @varB = @varA;
mysql> select @varB;
+-------+
| @varB |
+-------+
|     2 |
+-------+
    例2:
mysql> set @varA = 3; 
mysql> set @varB = @varA;
mysql> select @varB;                                             
+-------+
| @varB |
+-------+
|     3 |
+-------+
    

    3.2 通過select的實例
    相對set語句而言,使用select定義變量,會返回一個表格形式的結果。

mysql> select @var1:=1, @var2:='vartest', @var3:=abs(-2), @var4:=(select count(*) from mysql.user);
+----------+------------------+----------------+------------------------------------------+
| @var1:=1 | @var2:='vartest' | @var3:=abs(-2) | @var4:=(select count(*) from mysql.user) |
+----------+------------------+----------------+------------------------------------------+
|        1 | vartest          |              2 |                                       25 |
+----------+------------------+----------------+------------------------------------------+
mysql> select @var1, @var2, @var3, @var4;
+-------+---------+-------+-------+
| @var1 | @var2   | @var3 | @var4 |
+-------+---------+-------+-------+
|     1 | vartest |     2 |    25 |
+-------+---------+-------+-------+
+-------+---------+-------+-------+
|     1 | vartest |     2 |    25 |
+-------+---------+-------+-------+

4 用戶變量注意事項
    4.1 用戶變量用在where或having子句中,他們必須首先用另一條語句來定義,如下面例子,初次查詢沒有返回結果,先定以後在查詢纔有輸出。
mysql> select @H:='localhost' from mysql.user where host = @H;
Empty set (0.00 sec)
mysql> select @H:='localhost';
+-----------------+
| @H:='localhost' |
+-----------------+
| localhost       |
+-----------------+
1 row in set (0.00 sec)
mysql> select @H:='localhost', user from mysql.user where host = @H;
+-----------------+-----------------+
| @H:='localhost' | user            |
+-----------------+-----------------+
| localhost       |                 |
| localhost       | jesse           |
| localhost       | local           |
| localhost       | root            |
| localhost       | user_tab_update |
+-----------------+-----------------+

    4.2 用戶變量爲session級別,當我們關閉客戶端或退出登錄時用戶變量全部消失。如果想用就保存自定義的變量,需要自行創建一個表,將標量insert到表裏。
    4.3 用戶變量名對大小寫不敏感。
    4.4 未定義的變量初始化是null。
5 補充知識:mysql語句do

    在do語句中,使用了一個或多個標量表達式,mysql會一條一條的處理它們,但並不顯示錶達式的結果。例如我們可以調用函數執行後臺的某些事情,而不需要看到其結果。

    例如:

mysql> do sleep(5);
Query OK, 0 rows affected (5.00 sec)
****************************************************************************************
    原文地址:http://blog.csdn.net/jesseyoung/article/details/40779631
    博客主頁:http://blog.csdn.net/jesseyoung
****************************************************************************************
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章