国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

mysql用戶變量與set語句示例詳解

瀏覽:4日期:2023-10-08 08:05:44
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 |+-------+

mysql用戶變量與set語句示例詳解

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 |+-------+---------+-------+-------+

mysql用戶變量與set語句示例詳解

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)總結

到此這篇關于mysql用戶變量與set語句的文章就介紹到這了,更多相關mysql用戶變量與set語句內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: MySQL 數據庫
相關文章:
主站蜘蛛池模板: 亚洲天堂在线视频播放 | 欧美一区二区三区不卡免费 | a级网站在线观看 | 亚洲成在 | 成人夜色香网站在线观看 | 中文字幕一区二区三区在线观看 | 国产自偷自拍 | 欧美特黄一级视频 | 伊人久久在线视频 | 最新国产三级在线不卡视频 | 巨大热杵在腿间进进出出视频 | 男人的天堂高清在线观看 | 波多结衣一区二区三区 | 热久久在线观看 | 亚洲 欧美 日韩中文字幕一区二区 | 国产欧美日本在线 | 久久一日本道色综合久久m 久久伊人成人网 | 一区二区影院 | 久久99精品视免费看 | 亚洲精品高清在线 | 高清性色生活片久久久 | 日韩精品一区二区三区视频 | 高清成人 | 国产成人啪精品 | 日本三级2021最新理论在线观看 | 深夜福利网站 | 国产亚洲欧美日韩在线观看不卡 | 国产精品露脸脏话对白 | 九九99久久 | 久久久久久免费观看 | 成人影院久久久久久影院 | 国产亚洲精品国看不卡 | 国产精品久久自在自线观看 | 国产永久免费高清动作片www | 欧美aaaaa| 成人日韩在线观看 | 免费永久在线观看黄网 | 成人欧美一区二区三区视频xxx | 最近手机中文在线视频 | 国产成人艳妇在线观看 | caoporen免费公开视频上传 |