【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();

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

相关推荐
火飞鹰3 小时前
封装MinIO为starter
java·数据库·spring boot
升职佳兴4 小时前
SQL 进阶3:连续登录问题与 ROW_NUMBER 差值法完整解析
java·数据库·sql
Chris _data4 小时前
从宿主机(Windows)通过 NAT 模式连接虚拟机(Ubuntu)中的 MySQL
windows·mysql·ubuntu
我是永恒4 小时前
PostgreSQL数据库安装配置连接Paperclip
数据库·postgresql
巧妹儿4 小时前
AI Agent 实战:MySQL 监控指标查询 Skill|华为云 + 腾讯云双兼容可直接复用
python·mysql·ai·大模型·华为云·腾讯云
一个天蝎座 白勺 程序猿4 小时前
踩坑生产后整理:KingbaseES表空间管理、auto_createtblspcdir参数深度解析与运维最佳实践
运维·数据库·kingbasees
oG99bh7CK4 小时前
FastAPI + PostgreSQL 实战:从入门到不踩坑,一次讲透
数据库·postgresql·fastapi
Wait....4 小时前
MySQL事务知识复习
数据库·mysql
杨云龙UP4 小时前
Oracle 19c:RMAN Duplicate异机复制数据库实操_20260402
linux·运维·服务器·数据库·网络协议·tcp/ip·oracle
刘~浪地球4 小时前
Redis 从入门到精通(七):集合操作详解
数据库·chrome·redis