根据尚硅谷的视频教程学习MySQL,学习记录-14 - 变量。
系统变量:全局变量 | 会话变量
自定义变量:用户变量 | 局部变量
一、系统变量
说明:变量由系统提供,不是用户定义的,属于服务器层面
全局变量作用域:服务器每次启动将为所有的全局变量赋初始值,针对于所有的会话、连接有效,但是不能跨重启
会话变量作用域:只针对于当前的会话、连接有效
使用语法:
- 查看所有的系统变量
SHOW SESSION VARIABLES; #查看会话变量,session可以省略
SHOW GLOBAL VARIABLES; #查看全局变量
- 查看满足条件的部分系统变量
SHOW GLOBAL | SESSION VARIABLES LIKE '%char%;
- 查看指定的某个系统变量的值
SELECT @@系统变量名;
SELECT @@global.系统变量名;
- 为某个系统变量赋值
SET GLOBAL | SESSION 系统变量名 = 值;
SET @@global.系统变量名 = 值;
二、自定义变量 - 用户变量
说明:变量是用户自定义的
使用步骤:声明 -> 赋值 -> 使用 (查看、比较、运算等)
用户变量作用域:针对当前会话、连接有效,与会话变量的作用域相同;应用在任何地方
- 声明并初始化,赋值的操作符:= 或 :=
SET @用户变量名 = 值;
SET @用户变量名 := 值;
SELECT @用户变量名 := 值;
- 赋值(更新用户变量的值)
方式一:通过SET和SELECT语句
SET @用户变量名 = 值;
SET @用户变量名 := 值;
SELECT @用户变量名 := 值;
方式二:通过select into
SELECT 字段 INTO 变量名 FROM 表;
- 使用(查看变量的值)
SELECT @用户变量名
举例:
SET @name = 'John'; #定义变量name,赋值为 John
SET @account = 1; #定义变量account,赋值为 1
select count(*) into @count
FROM employees; #定义变量count,赋值为employees表中的记录条数
SELECT @count; #查看变量count的数值
三、自定义变量 - 局部变量
局部变量作用域:仅在定义它的begin end中有效,并且是Begin end中的第一句话
- 声明
DECLARE 变量名 类型;
DECLARE 变量名 类型 DEFAULT 值;
- 赋值
方式一:用过SET或SELECT
SET 局部变量名 = 值;
SET 局部变量名 :=值;
SELECT @局部变量名 := 值;
方式二:通过SELECT ITO
SELECT 字段 INTO 局部变量名 FROM 表;
- 使用
select 局部变量名;
练习:
declare m int default 1; #定义变量m,默认值为1
declare n int default 2;#定义变量n,默认值为2
declare sum int; #定义变量sum为整型
set sum =m+n; # 为sum赋值
select sum; #使用sum