【MySQL】变量

在MySQL中变量可以分为三类:系统变量、用户自定义变量、以及局部变量。

首先聊聊系统变量

系统变量是MySQL服务器的配置变量,控制着服务器的行为和性能。分为全局变量(GLOBAL)和会话变量(SESSION)。

在Linux中的MySQL的配置文件默认是在:/etc/mysql/mysql.conf.d/下里有mysqld.cnf里面有很多系统变量

查看系统变量

sql 复制代码
-- 查看所有系统变量
SHOW [GLOBAL|SESSION] VARIABLES;
-- 查看指定的系统变量
SHOW [GLOBAL|SESSION] VARIABLES LIKE 'xxx';
-- 查看指定的系统变量,可以通过LKIE进⾏模糊查询
SHOW [GLOBAL|SESSION] VARIABLES like '%xxx%';
-- 使⽤SELECT查看指定系统变量
SELECT @@[GLOBAL|SESSION].系统变量名;
-- ----------------------------------------------------
-- ⽰例:查看以auto开头的全局系统变量
SHOW GLOBAL VARIABLES LIKE 'auto%';
-- ⽰例:查看以char开头的会话系统变量
SHOW SESSION VARIABLES LIKE 'char%';
-- ⽰例:查看事务⾃动提交全局系统变量
SELECT @@GLOBAL.autocommit;

设置系统变量:

sql 复制代码
SET [GLOBAL|SESSION] 系统变量名 = 值;
SET @@SESSION.系统变量名 = 值;
-- -------------------------------------------
-- ⽰例:设置事务⾃动提交会话变量为关闭/开启
SET @@SESSION.autocommit = 0;
SET autocommit = 1;

注意:

如果没有指定GLOBAL|SESSION,默认设置会话(SESSION)全局变量

会话关闭后,设置的会话(SESSION)变量失效;新建的会话读取全局系统变量的值做为初始值。

MySQL重启后,设置的全局(GLOBAL)变量失效,如果想使全局系统变量永久生效,需要修改选

项文件


用户自定义变量

用户自定义变量是在SQL会话中定义的变量,不用提前声明,作用域为当前会话。

赋值操作主要包括两种= 和:=:

举个例子:

sql 复制代码
-- ⽰例:定义⼀个age变量并赋值为18,并查看
SET @age := 18;
SELECT @age;
-- ⽰例:从学⽣表中查询编号为1的学⽣学号并赋值给sno变量
SELECT sno INTO @sno from student where id = 1;
SELECT @sno;
-- ⽰例:查询学⽣表中的总记录数并赋值给conut变量
SELECT count(*) INTO @count from student;
SELECT @count;
-- ⽰例:访问⼀个未赋值的变量,返回NULL
SELECT @var;

由于SQL中比较比较相等也是用等号 (=),所以在为变量赋值的时候推荐使用 ( := ),只要是赋值,就用:=就完了。


局部变量
局部变量只在存储过程、函数或触发器的范围内有效 。需要使用 DECLARE 声明,作用域的范围在声明的 BEGIN ... END 块内

变量可以是任何有效的MySQL数据类型,如 INT 、 VARCHAR 、 DATETIME 等

cpp 复制代码
DECLARE 变量名 变量类型 [DEFAULT 默认值] ...;

举个例子:

sql 复制代码
delimiter //
-- 定义存储过程
create procedure p1()
BEGIN
-- 定义局部变量
  declare stu_count int default 0;
  select count(*) into stu_count from student;
  select stu_count;
END//
delimiter ;

call p1();

部变量在存储过程或函数结束时失效

相关推荐
小羽网安2 小时前
从零开始学习 sql 注入,常见的 sql 注入解析
数据库·sql·学习
2401_846339563 小时前
CSS如何优化大型项目样式_使用SASS预处理器提升开发效率
jvm·数据库·python
ss2739 小时前
食谱推荐系统功能测试如何写?
java·数据库·spring boot·功能测试
l1t10 小时前
DeepSeek总结的数据库外部表
数据库
m0_6742946410 小时前
如何编写SQL存储过程性能对比_记录执行时间评估优化效果
jvm·数据库·python
014-code10 小时前
CompletableFuture 实战模板(超时、组合、异常链处理)
java·数据库
运气好好的10 小时前
怎样开启phpMyAdmin的操作审计日志_记录每条执行的SQL
jvm·数据库·python
それども11 小时前
DELETE 和 TRUNCATE TABLE区别
java·数据库·mysql
wenha11 小时前
数据库隔离级别
数据库·mysql·sqlserver·隔离级别
2401_8714928511 小时前
Layui如何修改Layui默认的UI主题颜色(换肤功能实现)
jvm·数据库·python