一、系統變量
說明:變量由系統提供,不是用戶定義,屬於服務器層面注意
:如果全局級別,則需要加global,如果是會話級別,則需要加session,如果不寫,則默認session
語法:
-
查看所有系統變量
show global|[session] variables // show variables不寫默認查會員變量
-
查看滿足條件的部分系統變量
show global|[session] variables like '%char%'
-
查看指定的某個系統變量的值
select @@global|[session].系統變量
-
爲某個系統變量賦值
方式一: set global|[session] 系統變量名 = 值 方式二: set @@global|[session].系統變量名 = 值
全局變量(global)作用域:服務器每次啓動將爲所有的全局變量賦初始值,針對於所有的會話(連接)有效,但不能跨重啓
會話變量(session)作用域:僅僅在當前會話(連接)有效
二、自定義變量
說明:變量是用戶自定義的,不是系統的
使用步驟:聲明、賦值、使用(查看、比較、運算等)
- 用戶變量
作用域:針對當前會話(連接)有效,同於會話變量的作用域
賦值操作符:=或:=
-
聲明並初始化:
set @用戶變量名=值;或 set @用戶變量名:=;或 select @用戶變量名:=值
-
賦值:
方式一: set @用戶變量名=值;或 set @用戶變量名:=;或 select @用戶變量名:=值 方式二: 通過select into select 字段 into @變量名 from 表
-
查看:
select @變量名
- 局部變量
作用域:僅僅在定義它的begin end 中有效應用在begin end 中的第一句話
-
聲明:
declare 變量名 類型; declare 變量名 類型 default 值
-
賦值:
方式一: 通過set 或 select set 局部變量名=值;或 set 局部變量名:=值;或 select @局部變量名:=值 方式二: 通過select into select 字段 into 局部變量名 from 表;
-
使用:
select 局部變量名;