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

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

相关推荐
柒.梧.1 小时前
拆解Spring核心:IOC与AOP底层原理
数据库
遨游xyz1 小时前
Trie树(字典树)
开发语言·python·mysql
一个天蝎座 白勺 程序猿2 小时前
国产数据库破局之路——KingbaseES与MongoDB替换实战:从场景到案例的深度解析
开发语言·数据库·mongodb·性能优化·kingbasees·金仓数据库
thginWalker2 小时前
演进篇 · 维护篇
服务器·数据库
cm_chenmin2 小时前
Cursor最佳实践之二:提问技巧
数据库·log4j
番茄去哪了2 小时前
python基础入门(一)
开发语言·数据库·python
人道领域2 小时前
MyBatis-Plus为何用JavaBean映射数据库表及乐观锁实战
java·开发语言·数据库
bai_lan_ya2 小时前
makefile通用解析
java·运维·数据库