变量 variables
MySQL本质是一种编程语言
1、系统变量
对所有用户客户端都有效
1.1、查看系统变量
1、方式一
sql
show variables [like 'pattern'];
示例
sql
mysql> show variables like 'autocommit';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| autocommit | ON |
+---------------+-------+
2、方式二:
使用select查询变量的数据值
sql
select @@变量名;
示例
sql
select @@autocommit;
+--------------+
| @@autocommit |
+--------------+
| 1 |
+--------------+
1.2、修改系统变量
1、局部修改(会话级别)
sql
-- 只针对当前客户端当次连接有效
set 变量名 = 值;
-- eg:
set autocommit = 'off';
show variables like 'autocommit';
2、全局修改
sql
-- 所有客户端,都有效
set global 变量名 = 值;
set @@global.变量名 = 值;
-- eg:
set global autocommit = 'off';
注意,全局修改之后,重启客户端生效
2、会话变量
也称为用户变量,设置的变量,只针对当前用户使用的客户端生效
sql
-- 定义用户变量
set @变量名 = 值;
set @age = 23;
mysql中没有比较符号 == ,使用的是 =; 为了避免分不清是赋值还是比较,赋值使用:=
sql
set @变量名 := 值;
set @name := 'Tom';
mysql允许将数据从表中取出存储到变量中,只能是一行数据
sql
-- 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;
查看变量
sql
select @变量名
mysql> select @name, @age;
+--------+------+
| @name | @age |
+--------+------+
| 刘备 | 18 |
+--------+------+
3、局部变量
作用范围在begin到end语句块之间,在该语句块里设置的变量
- declare语句用于定义局部变量
- 局部变量 declare语句出现在begin到end语句块之间
声明语法
sql
declare 变量名 数据类型 [属性];
4、变量作用域
变量能够使用的区域范围
4.1、局部作用域
declare 关键字声明 (结构体中使用:函数/存储过程/触发器)
declare关键字声明的变量没有任何符号修饰,就是普通字符串,如果再外部访问该变量,系统会自动认为是字段
4.2、会话作用域
用户定义的,使用@符号定义的变量,使用set关键字
会话作用域,当次连接有效只要再本连接中,任何地方都可以使用(可以在结构内容,也可以跨库)
会话变量可以再函数内部使用
sql
set @name = '张三';
create function get_name() returns char(4)
return @name;
select get_name();
+------------+
| get_name() |
+------------+
| 张三 |
+------------+
会话变量可以跨库
sql
use mydatabase2;
mysql> select @name;
+--------+
| @name |
+--------+
| 张三 |
+--------+
4.3、全局作用域
所有的客户端,所有的连接都有效,需要使用全局符号来定义
sql
set global 变量名 = 值;
set @@global.变量名 = 值;
通常,在sql编程的时候,不会使用自定义变量来控制全局,一般定义会话变量或者结构中使用局部变量来解决问题