首頁 > 軟體

MySQL詳細講解變數variables的用法

2022-06-18 14:02:14

變數 variables

MySQL本質是一種程式語言

1、系統變數

對所有使用者使用者端都有效

1.1、檢視系統變數

1、方式一

show variables [like 'pattern'];

範例

mysql> show variables like 'autocommit';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| autocommit    | ON    |
+---------------+-------+

2、方式二:

使用select查詢變數的資料值

select @@變數名;

範例

select @@autocommit;
+--------------+
| @@autocommit |
+--------------+
|            1 |
+--------------+

1.2、修改系統變數

1、區域性修改(對談級別)

-- 只針對當前使用者端當次連線有效
set 變數名 = 值;
-- eg:
set autocommit = 'off';
show variables like 'autocommit';

2、全域性修改

-- 所有使用者端,都有效
set global 變數名 = 值;
set @@global.變數名 = 值;
-- eg:
set global autocommit = 'off';

注意,全域性修改之後,重啟使用者端生效

2、對談變數

也稱為使用者變數,設定的變數,只針對當前使用者使用的使用者端生效

-- 定義使用者變數
set @變數名 = 值;
set @age = 23;

mysql中沒有比較符號 == ,使用的是 =;
為了避免分不清是賦值還是比較,賦值使用:=

set @變數名 := 值;
set @name := 'Tom';

mysql允許將資料從表中取出儲存到變數中,只能是一行資料

-- 1、賦值且檢視賦值過程
select @變數1 := 欄位1, @變數2 := 欄位2 from 表 where 條件
select @name := name, @age := age from my_student limit 1;
+---------------+-------------+
| @name := name | @age := age |
+---------------+-------------+
| 劉備          |          18 |
+---------------+-------------+
--- 2、只賦值不看過程
select 欄位1, 欄位2 from 表 where 條件 into @變數1, @變數2;
select name, age from my_student limit 1 into @name, @age;

檢視變數

select @變數名
mysql> select @name, @age;
+--------+------+
| @name  | @age |
+--------+------+
| 劉備   |   18 |
+--------+------+

3、區域性變數

作用範圍在begin到end語句塊之間,在該語句塊裡設定的變數

  • declare語句用於定義區域性變數
  • 區域性變數 declare語句出現在begin到end語句塊之間

宣告語法

declare 變數名 資料型別 [屬性];

4、變數作用域

變數能夠使用的區域範圍

4.1、區域性作用域

declare 關鍵字宣告 (結構體中使用:函數/儲存過程/觸發器)

declare關鍵字宣告的變數沒有任何符號修飾,就是普通字串,如果再外部存取該變數,系統會自動認為是欄位

4.2、對談作用域

使用者定義的,使用@符號定義的變數,使用set關鍵字

對談作用域,當次連線有效只要再本連線中,任何地方都可以使用(可以在結構內容,也可以跨庫)

對談變數可以再函數內部使用

set @name = '張三';
create function get_name() returns char(4)
return @name;
select get_name();
+------------+
| get_name() |
+------------+
| 張三       |
+------------+

對談變數可以跨庫

use mydatabase2;
mysql> select @name;
+--------+
| @name  |
+--------+
| 張三   |
+--------+ 

4.3、全域性作用域

所有的使用者端,所有的連線都有效,需要使用全域性符號來定義

set global 變數名 = 值;
set @@global.變數名 = 值;

通常,在sql程式設計的時候,不會使用自定義變數來控制全域性,一般定義對談變數或者結構中使用區域性變數來解決問題

到此這篇關於MySQL詳細講解變數variables的用法的文章就介紹到這了,更多相關MySQL variables內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!


IT145.com E-mail:sddin#qq.com