mysql用戶變量與set語句示例詳解
用戶變量即用戶自己定義的變量,我們可以給用戶變量分配值,并且可用在任何可以正常使用標(biāo)量表達(dá)式的地方。
引入用戶變量之前我們必須使用set語句或select語句來定義它,然后為它賦一個值,否則變量就只有一個空值。
用戶變量與連接有關(guān)。也就是說,一個客戶端定義的變量不能被其它客戶端看到或使用。當(dāng)客戶端退出時,該客戶端連接的所有變量將自動釋放。
2 用戶變量定義set語句可用于向系統(tǒng)變量或用戶變量賦值,針對用戶變量的定義如下:
SET @var_name = expr [, @var_name = expr] ...
也可使用select語句來定義:
SELECT @var_name := expr [, @var_name = expr] ...
用戶變量:以'@'開始,形式為'@var_name',以區(qū)分用戶變量及列名。它可以是任何隨機(jī)的,復(fù)合的標(biāo)量表達(dá)式,只要其中沒有列指定。
一個變量名可以由當(dāng)前字符集的數(shù)字字母字符和“_”、“$”和“.”組成。缺省字符集是ISO-8859-1 Latin1;這可以用mysqld 的--default-character-set 選項(xiàng)更改字符集。
對于SET,可以使用=或:=來賦值,對于SELECT只能使用:=來賦值。
我們可以使用一條簡單的select語句查詢定義的用戶變量的值。
3 用戶變量的使用3.1 通過set的實(shí)例用來把一個值賦給一個變量的標(biāo)量表達(dá)式可以是復(fù)合表達(dá)式。計(jì)算,函數(shù),系統(tǒng)標(biāo)量以及其他用戶變量都是允許的,子查詢也是允許的。然后通過select語句可以獲取一個用戶變量的值,結(jié)果是帶有一行的一個表。
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 |+-------+---------+-------+-------+
在用來為一個用戶變量賦值的表達(dá)式中,也可以指定其它的用戶變量,需要注意的是mysql首先確定所有表達(dá)式的值,之后才會把值賦給變量。
例如:
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 |+-------+
相對set語句而言,使用select定義變量,會返回一個表格形式的結(jié)果。
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.1 用戶變量用在where或having子句中,他們必須首先用另一條語句來定義,如下面例子,初次查詢沒有返回結(jié)果,先定以后在查詢才有輸出。
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級別,當(dāng)我們關(guān)閉客戶端或退出登錄時用戶變量全部消失。如果想用就保存自定義的變量,需要自行創(chuàng)建一個表,將標(biāo)量insert到表里。
4.3 用戶變量名對大小寫不敏感。
4.4 未定義的變量初始化是null。
5 補(bǔ)充知識:mysql語句do在do語句中,使用了一個或多個標(biāo)量表達(dá)式,mysql會一條一條的處理它們,但并不顯示表達(dá)式的結(jié)果。例如我們可以調(diào)用函數(shù)執(zhí)行后臺的某些事情,而不需要看到其結(jié)果。
例如:
mysql> do sleep(5);Query OK, 0 rows affected (5.00 sec)總結(jié)
到此這篇關(guān)于mysql用戶變量與set語句的文章就介紹到這了,更多相關(guān)mysql用戶變量與set語句內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. MySQL InnoDB 鎖的相關(guān)總結(jié)2. 學(xué)好Oracle的六條總結(jié)3. 簡單了解mysql語句書寫和執(zhí)行順序4. Mysql入門系列:MYSQL客戶機(jī)程序2—增加錯誤檢查5. MySQL中InnoDB和MyISAM類型的差別6. Mysql入門系列:建立MYSQL客戶機(jī)程序的一般過程7. DB2 與 Microsoft SQL Server 2000 之間的 SQL 數(shù)據(jù)復(fù)制8. MySql遠(yuǎn)程連接的實(shí)現(xiàn)方法9. mysql的like模式10. Windows下在DOS用mysql命令行導(dǎo)入.sql文件
