您好,登錄后才能下訂單哦!
mysql數(shù)據(jù)庫(kù)中怎么使用set語(yǔ)句定義用戶變量?很多新手對(duì)此不是很清楚,為了幫助大家解決這個(gè)難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來(lái)學(xué)習(xí)下,希望你能有所收獲。
用戶變量即用戶自己定義的變量,我們可以給用戶變量分配值,并且可用在任何可以正常使用標(biāo)量表達(dá)式的地方。
引入用戶變量之前我們必須使用set語(yǔ)句或select語(yǔ)句來(lái)定義它,然后為它賦一個(gè)值,否則變量就只有一個(gè)空值。
用戶變量與連接有關(guān)。也就是說(shuō),一個(gè)客戶端定義的變量不能被其它客戶端看到或使用。當(dāng)客戶端退出時(shí),該客戶端連接的所有變量將自動(dòng)釋放。
set語(yǔ)句可用于向系統(tǒng)變量或用戶變量賦值,針對(duì)用戶變量的定義如下:
SET @var_name = expr [, @var_name = expr] ...
也可使用select語(yǔ)句來(lái)定義:
SELECT @var_name := expr [, @var_name = expr] ...
用戶變量:以"@"開(kāi)始,形式為"@var_name",以區(qū)分用戶變量及列名。它可以是任何隨機(jī)的,復(fù)合的標(biāo)量表達(dá)式,只要其中沒(méi)有列指定。
一個(gè)變量名可以由當(dāng)前字符集的數(shù)字字母字符和“_”、“$”和“.”組成。缺省字符集是ISO-8859-1 Latin1;這可以用mysqld 的--default-character-set 選項(xiàng)更改字符集。
對(duì)于SET,可以使用=或:=來(lái)賦值,對(duì)于SELECT只能使用:=來(lái)賦值。
我們可以使用一條簡(jiǎn)單的select語(yǔ)句查詢定義的用戶變量的值。
用來(lái)把一個(gè)值賦給一個(gè)變量的標(biāo)量表達(dá)式可以是復(fù)合表達(dá)式。計(jì)算,函數(shù),系統(tǒng)標(biāo)量以及其他用戶變量都是允許的,子查詢也是允許的。然后通過(guò)select語(yǔ)句可以獲取一個(gè)用戶變量的值,結(jié)果是帶有一行的一個(gè)表。
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 | +-------+---------+-------+-------+
在用來(lái)為一個(gè)用戶變量賦值的表達(dá)式中,也可以指定其它的用戶變量,需要注意的是mysql首先確定所有表達(dá)式的值,之后才會(huì)把值賦給變量。
例如:
mysql> set @varA = 2;
對(duì)于下面兩個(gè)例子,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 | +-------+
相對(duì)set語(yǔ)句而言,使用select定義變量,會(huì)返回一個(gè)表格形式的結(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子句中,他們必須首先用另一條語(yǔ)句來(lái)定義,如下面例子,初次查詢沒(méi)有返回結(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級(jí)別,當(dāng)我們關(guān)閉客戶端或退出登錄時(shí)用戶變量全部消失。如果想用就保存自定義的變量,需要自行創(chuàng)建一個(gè)表,將標(biāo)量insert到表里。
4.3 用戶變量名對(duì)大小寫(xiě)不敏感。
4.4 未定義的變量初始化是null。
在do語(yǔ)句中,使用了一個(gè)或多個(gè)標(biāo)量表達(dá)式,mysql會(huì)一條一條的處理它們,但并不顯示表達(dá)式的結(jié)果。例如我們可以調(diào)用函數(shù)執(zhí)行后臺(tái)的某些事情,而不需要看到其結(jié)果。
例如:
mysql> do sleep(5); Query OK, 0 rows affected (5.00 sec)
看完上述內(nèi)容是否對(duì)您有幫助呢?如果還想對(duì)相關(guān)知識(shí)有進(jìn)一步的了解或閱讀更多相關(guān)文章,請(qǐng)關(guān)注億速云行業(yè)資訊頻道,感謝您對(duì)億速云的支持。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。