色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

mysql用戶(hù)變量與set語(yǔ)句示例詳解

瀏覽:3日期:2023-10-08 08:05:44
1 用戶(hù)變量介紹

用戶(hù)變量即用戶(hù)自己定義的變量,我們可以給用戶(hù)變量分配值,并且可用在任何可以正常使用標(biāo)量表達(dá)式的地方。

引入用戶(hù)變量之前我們必須使用set語(yǔ)句或select語(yǔ)句來(lái)定義它,然后為它賦一個(gè)值,否則變量就只有一個(gè)空值。

用戶(hù)變量與連接有關(guān)。也就是說(shuō),一個(gè)客戶(hù)端定義的變量不能被其它客戶(hù)端看到或使用。當(dāng)客戶(hù)端退出時(shí),該客戶(hù)端連接的所有變量將自動(dòng)釋放。

2 用戶(hù)變量定義

set語(yǔ)句可用于向系統(tǒng)變量或用戶(hù)變量賦值,針對(duì)用戶(hù)變量的定義如下:

SET @var_name = expr [, @var_name = expr] ...

也可使用select語(yǔ)句來(lái)定義:

SELECT @var_name := expr [, @var_name = expr] ...

用戶(hù)變量:以'@'開(kāi)始,形式為'@var_name',以區(qū)分用戶(hù)變量及列名。它可以是任何隨機(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ǔ)句查詢(xún)定義的用戶(hù)變量的值。

3 用戶(hù)變量的使用3.1 通過(guò)set的實(shí)例

用來(lái)把一個(gè)值賦給一個(gè)變量的標(biāo)量表達(dá)式可以是復(fù)合表達(dá)式。計(jì)算,函數(shù),系統(tǒng)標(biāo)量以及其他用戶(hù)變量都是允許的,子查詢(xún)也是允許的。然后通過(guò)select語(yǔ)句可以獲取一個(gè)用戶(hù)變量的值,結(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è)用戶(hù)變量賦值的表達(dá)式中,也可以指定其它的用戶(hù)變量,需要注意的是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 |+-------+

mysql用戶(hù)變量與set語(yǔ)句示例詳解

3.2 通過(guò)select的實(shí)例

相對(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 |+-------+---------+-------+-------+

mysql用戶(hù)變量與set語(yǔ)句示例詳解

4 用戶(hù)變量注意事項(xiàng)

4.1 用戶(hù)變量用在where或having子句中,他們必須首先用另一條語(yǔ)句來(lái)定義,如下面例子,初次查詢(xún)沒(méi)有返回結(jié)果,先定以后在查詢(xún)才有輸出。

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 用戶(hù)變量為session級(jí)別,當(dāng)我們關(guān)閉客戶(hù)端或退出登錄時(shí)用戶(hù)變量全部消失。如果想用就保存自定義的變量,需要自行創(chuàng)建一個(gè)表,將標(biāo)量insert到表里。

4.3 用戶(hù)變量名對(duì)大小寫(xiě)不敏感。

4.4 未定義的變量初始化是null。

5 補(bǔ)充知識(shí):mysql語(yǔ)句do

在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)總結(jié)

到此這篇關(guān)于mysql用戶(hù)變量與set語(yǔ)句的文章就介紹到這了,更多相關(guān)mysql用戶(hù)變量與set語(yǔ)句內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: MySQL 數(shù)據(jù)庫(kù)
相關(guān)文章:
主站蜘蛛池模板: 国产永久在线观看 | 国产激情视频在线播放 | 亚洲欧美日韩在线精品一区二区 | 女人张开腿男人捅 | 日本精品夜色视频一区二区 | 精品午夜寂寞黄网站在线 | 欧美骚视频 | 美女黄视频免费观看 | 久久狠狠色狠狠色综合 | 亚洲精品午夜 | 久久羞羞 | 国产美女一级毛片 | 国产精品毛片天天看片 | 精品免费视频 | 久久精品国产99国产精品免费看 | 成人男男黄网色视频免费 | 国产美女动态免费视频 | 久久免费视频在线观看 | 波多野结衣在线观看一区二区三区 | 午夜免费成人 | 国模偷拍在线观看免费视频 | 国产精选经典三级小泽玛利亚 | 日韩美女网站在线看 | 97se亚洲综合在线韩国专区福利 | 日韩精品一区在线观看 | 欧美综合在线视频 | 深夜福利视频网站 | 中文字幕亚洲精品 | 欧美人一级淫片a免费播放 欧美人与z0z0xxxx | 国产精品一区伦免视频播放 | 国产精品网址 | 中文字幕亚洲精品日韩精品 | 国产精品理论片 | 加勒比在线免费视频 | 日本高清aⅴ毛片免费 | 一级毛片大全 | 手机看片国产 | 国产一区二区三区在线观看免费 | 四川一级片 | 亚洲天堂男 | 日韩欧美精品综合一区二区三区 |