一、系统变量
说明:变量由系统提供,不是用户定义,属于服务器层面注意
:如果全局级别,则需要加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 局部变量名;
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。