[MySQL]变量

news2025/1/8 12:18:56

文章目录

  • 1. 变量
    • 1.1 系统变量
      • 1.1.1 系统变量分类
      • 1.1.2 查看系统变量
        • 查看所有系统变量
        • 查询部分系统变量
        • 查看指定系统变量
      • 1.1.3 修改系统变量
        • 方式一:修改配置文件
        • 方式二:使用 set 设置系统变量的值
    • 1.2 用户变量
      • 1.2.1 用户变量的分类
      • 1.2.2 会话用户变量
        • 变量的声明与赋值
        • 变量的使用
        • 代码示例
      • 1.2.3 局部变量
        • 局部变量的声明
        • 局部变量的赋值
        • 使用局部变量
        • 代码示例
      • 1.2.4 练习
      • 1.2.5 对比会话用户变量与局部变量


1. 变量

在MySQL数据库的存储过程和函数中,可以使用变量来存储查询或计算的中间结果数据,或者输出最终的结果数据。

在 MySQL 数据库中,变量分为 系统变量 以及 用户自定义变量

1.1 系统变量

变量由系统定义,不是用户定义,属于 服务器 层面。

启动MySQL服务,生成MySQL服务实例期间,MySQL将为MySQL服务器内存中的系统变量赋值,这些系统变量定义了当前MySQL服务实例的属性、特
征。这些系统变量的值要么是 编译MySQL时参数 的默认值,要么是 配置文件 (例如my.ini等)中的参数值。

1.1.1 系统变量分类

系统变量分为全局系统变量(需要添加 global 关键字)以及会话系统变量(需要添加 session 关键字)。

有时也把全局系统变量简称为全局变量,有时也把会话系统变量称为local变量。如果不写变量是全局系统变量还是会话系统变量,默认是会话级别。

每一个MySQL客户机成功连接MySQL服务器后,都会产生与之对应的会话。会话期间,MySQL服务实例会在MySQL服务器内存中生成与该会话对应的会话系统变量,这些会话系统变量的初始值是全局系统变量值的复制。
在这里插入图片描述

在MySQL中,有些全局系统变量是所有会话共享的,一个会话对值进行了修改,所有会话中相应的全局系统变量的值也会发生修改;而有些全局系统变量既是全局系统变量又是会话系统变量(这个会话系统变量相当于全局系统变量的副本),此时的全局系统变量和会话系统变量一样,每个会话都有自己的系统变量,不同会话之间的不会发生干扰。

在MySQL中有些系统变量只能是全局的,例如 max_connections 用于限制服务器的最大连接数;有些系统变量作用域既可以是全局又可以是会话,例如 character_set_client 用于设置客户端的字符集;有些系统变量的作用域只能是当前会话,例如 pseudo_thread_id 用于标记当前会话的 MySQL 连接 ID。

在这里插入图片描述

  • 全局系统变量针对于所有会话(连接)有效,但 不能跨重启,一旦重启,会重新进行系统默认值的赋值;
  • 会话系统变量仅针对于当前会话(连接)有效。会话期间,当前会话对某个会话系统变量值的修改,不会影响其他会话同一个会话系统变量的值。
  • 会话1对某个全局系统变量值的修改会导致会话2中同一个全局系统变量值的修改。

1.1.2 查看系统变量

查看所有系统变量

# 查看所有的全局变量
SHOW GLOBAL VARIABLES;

在这里插入图片描述

# 查看所有会话变量
SHOW SESSION VARIABLES;
SHOW VARIABLES; # 不指定变量的级别,默认为会话级别

在这里插入图片描述

查询部分系统变量

# 查看部分的全局变量
SHOW GLOBAL VARIABLES LIKE 'admin_%';

在这里插入图片描述

# 查看部分会话变量
SHOW SESSION VARIABLES LIKE 'character_%';
SHOW VARIABLES LIKE 'character_%';

在这里插入图片描述

查看指定系统变量

作为 MySQL 编码规范,MySQL 中的系统变量以 两个“@” 开头,其中 “@@global”仅用于标记全局系统变量“@@session”仅用于标记会话系统变量“@@” 首先标记会话系统变量,如果会话系统变量不存在,则标记全局系统变量,即先在会话系统变量中进行查找,查找不到,再到全局系统变量中查找

# 查看指定全局系统变量
SELECT @@global.max_connections;

在这里插入图片描述

# 查看指定会话系统变量
SELECT @@session.character_set_client;

在这里插入图片描述

# 查看指定系统变量
# 先查询会话系统变量,在查询全局系统变量
SELECT @@character_set_client;

在这里插入图片描述

1.1.3 修改系统变量

方式一:修改配置文件

修改MySQL 配置文件 ,继而修改MySQL系统变量的值(该方法需要重启MySQL服务) 。

方式二:使用 set 设置系统变量的值

在MySQL服务运行期间,使用“set”命令重新设置系统变量的值。

#修改全局系统变量
#方式1:
SET @@global.变量名=变量值;
#方式2:
SET GLOBAL 变量名=变量值;
#修改会话系统变量
#方式1:
SET @@session.变量名=变量值;
#方式2:
SET SESSION 变量名=变量值;
# 修改全局系统变量
SET @@global.max_connections = 100;
SET GLOBAL max_connections = 100;

SELECT @@max_connections;

在这里插入图片描述

这个修改全局系统变量针对于当前MySQL服务器实例有效,重启MySQL服务,就失效了。

# 修改会话系统变量
SET @@session.character_set_client = 'gbk';
SET SESSION character_set_client = 'gbk';

SELECT @@character_set_client, @@global.character_set_client;

在这里插入图片描述

这个修改会话系统变量针对于当前会话有效,结束会话重新建立新的会话,就失效了。

1.2 用户变量

1.2.1 用户变量的分类

用户变量是用户自己定义的,作为 MySQL 编码规范,MySQL 中的用户变量以 一个“@” 开头

根据作用范围不同,用户变量分为 会话用户变量 和 局部变量 。

  • 会话用户变量:作用域和会话系统变量一样,只在 当前连接会话有效
  • 局部变量只在 BEGIN 和 END 语句块中有效。局部变量只能在 存储过程和函数 中使用。

由于会话用户变量与会话系统变量的作用域一样,所以需要进行区分,会话系统变量使用@@,而用户会话变量使用@,因为局部变量只在 BEGIN 和 END 语句块中有效,可以不用使用@与会话系统变量进行区分。

1.2.2 会话用户变量

变量的声明与赋值

#方式1:“=”或“:=”
# 使用 := 为变量赋值,可以与WHERE中等于条件判断进行区分
SET @用户变量 =;
SET @用户变量 :=;

#方式2:“:=” 或 INTO关键字
SELECT @用户变量 := 表达式 [FROM 等子句];
SELECT 表达式 INTO @用户变量 [FROM 等子句];

变量的使用

SELECT @用户变量

代码示例

SET @num1 = 1;
SET @num2 := 2;
SET @sum := @num1 + @num2;

# 查询不存在的用户变量返回NULL
SELECT @sum, @a;

在这里插入图片描述

SELECT @count := COUNT(*)
FROM employees;

SELECT @count;

在这里插入图片描述

SELECT AVG(salary) INTO @avg_sal
FROM employees;

SELECT @avg_sal;

在这里插入图片描述

1.2.3 局部变量

可以使用 DECLARE 语句定义一个局部变量,局部变量仅仅在定义它的 BEGIN … END 中有效,使用 DECLARE 语句定义一个局部变量只能放在 BEGIN … END 中,而且只能放在第一句

局部变量必须使用 DECLARE声明。

局部变量的声明

DECLARE 变量名 类型 [default]; # 如果没有DEFAULT子句,初始值为NULL

局部变量的赋值

方式1:一般用于赋简单的值

SET 局部变量名=;
SET 局部变量名:=;

方式2:一般用于赋表中的字段值

SELECT 字段名或表达式 INTO 局部变量名 FROM;

使用局部变量

SELECT 局部变量名;

代码示例

CREATE PROCEDURE test1()
BEGIN
    # 声明局部变量
    DECLARE a INT DEFAULT 0; # 默认值为0
    DECLARE b INT; # 默认值为NULL
    # 两个变量如果类型和默认值一样可以合并声明
    DECLARE c, d INT DEFAULT 1;
    DECLARE emp_name VARCHAR(25);

    # 赋值
    SET a = 100;
    SET c := 200;
    SELECT last_name INTO emp_name
    FROM employees
    WHERE employee_id = 101;

    # 使用局部变量
    SELECT a, b, c, d, emp_name;
END;

CALL test1();

请添加图片描述

1.2.4 练习

声明局部变量,并分别赋值为employees表中employee_id为102的last_name和salary

# 声明局部变量,并分别赋值为employees表中employee_id为102的last_name和salary
CREATE PROCEDURE test2()
BEGIN
    # 声明局部变量
    DECLARE emp_name VARCHAR(25);
    DECLARE sal DOUBLE(10, 2) DEFAULT 0;
    # 为局部变量赋值
    SELECT last_name, salary INTO emp_name, sal
    FROM employees
    WHERE employee_id = 102;
    # 使用局部变量
    SELECT emp_name, sal;
END;

CALL test2();

在这里插入图片描述

声明两个变量,求和并打印 (分别使用会话用户变量、局部变量的方式实现)

SET @num1 := 10;
SET @num2 := 20;
SET @sum := @num1 + @num2;

SELECT @sum;

在这里插入图片描述

CREATE PROCEDURE test3()
BEGIN
    DECLARE num1, num2, sum INT DEFAULT 0;
    SET num1 := 10;
    SET num2 := 20;
    SET sum := num1 + num2;
    SELECT sum;
END;

CALL test3();

在这里插入图片描述

创建存储过程“different_salary”查询某员工和他领导的薪资差距,并用IN参数emp_id接收员工id,用OUT参数dif_salary输出薪资差距结果。

# 创建存储过程“different_salary”查询某员工和他领导的薪资差距,并用IN参数emp_id接收员工
# id,用OUT参数dif_salary输出薪资差距结果。
CREATE PROCEDURE different_salary( IN emp_id INT, OUT dif_salary DOUBLE(10, 2))
BEGIN
    # 声明局部变量,保存员工工资和管理者工资
    DECLARE emp_sal, mgr_sal DOUBLE(10, 2) DEFAULT 0.0;
    # 查询赋值
    # 查询员工工资
    SELECT salary INTO emp_sal
    FROM employees
    WHERE employee_id = emp_id;
    # 查询管理者工资
    SELECT salary INTO mgr_sal
    FROM employees
    WHERE employee_id = (
        SELECT manager_id
        FROM employees
        WHERE employee_id = emp_id
        );
    # 为输出参数赋值
    SET dif_salary := mgr_sal - emp_sal;
END;

CALL different_salary(102, @dif_sal);
SELECT @dif_sal;

在这里插入图片描述

1.2.5 对比会话用户变量与局部变量

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1961.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Maven

Maven是专门用于管理和构建Java项目的工具,它的主要功能有: 提供了一套标准化的项目结构提供了一套标准化的构建流程(编译,测试,打包,发布...)提供了一套依赖管理机制标准化的项目结构 不同IDE之…

C++语法——详细剖析多态与虚函数

目录 一.虚函数与多态的概念与基本使用 (一).概念 (二).基本使用 二.虚函数的底层 三.特殊的虚函数(协变) 四.多态在多继承、菱形继承与菱形虚拟继承中的使用。 (一).多继承 …

C语言分支与循环实战篇-猜数字小游戏/关机小程序

前言 👻作者:龟龟不断向前 👻简介:宁愿做一只不停跑的慢乌龟,也不想当一只三分钟热度的兔子。 👻专栏:C初阶知识点 👻工具分享: 刷题: 牛客网 leetcode笔记软…

大一学生HTML5期末大作业——基于HTML+CSS制作传统节日美食13页(美食网站设计与实现)

🎀 精彩专栏推荐👇🏻👇🏻👇🏻 ✍️ 作者简介: 一个热爱把逻辑思维转变为代码的技术博主 💂 作者主页: 【主页——🚀获取更多优质源码】 🎓 web前端期末大作业…

[LeetCode周赛复盘] 第 317 场周赛20221030

[LeetCode周赛复盘] 第 317 场周赛20221030 一、本周周赛总结二、 [Easy] 6220. 可被三整除的偶数的平均值1. 题目描述2. 思路分析3. 代码实现三、[Medium] 6221. 最流行的视频创作者1. 题目描述2. 思路分析3. 代码实现四、[Medium] 6222. 美丽整数的最小增量1. 题目描述2. 思路…

终极Hadoop大数据教程

终极Hadoop大数据教程 包含 MapReduce、HDFS、Spark、Flink、Hive、HBase、MongoDB、Cassandra、Kafka 等的数据工程和 Hadoop 教程! 课程英文名:The Ultimate Hands-On Hadoop - Tame your Big Data! 此视频教程共17.0小时,中英双语字幕&…

1.3 信号处理函数,创建worker进程

文章目录1、信号处理函数2、创建worker线程3、sigsuspend函数说明4、write函数思考1、信号处理函数 1、初始化信号的函数,用于注册信号处理程序 2、信号处理函数 初始化信号函数,遍历结构体数组,然后给结构体数组中的每个成员注册信号处理函数…

python实现自动检测核酸用码记录 ---- 自动化办公小技巧(摸鱼利器)

自动检测核酸用码记录🥇预备知识✈️os库os.path.exists()os.mkdir()os.remove()os.listdir()👽Python 3 查看字符编码方法⏰python3获取当前系统时间🐤读取图片,保存到指定目录👼将数据保存到csv文件中🥈p…

使用html+css实现一个静态页面(含源码)

HTML实例网页代码, 本实例适合于初学HTML的同学。该实例里面有设置了css的样式设置,有div的样式格局,这个实例比较全面,有助于同学的学习,本文将介绍如何通过从头开始设计个人网站并将其转换为代码的过程来实践设计。 文章目录一、网页介绍一…

freeRTOS学习(三)

任务管理 任务功能:任务以C函数的形式实现。唯一特别的地方是它们的原型,它必须返回void并接受一个void指针形参。 void ATaskFunction(void *pvParameters);**每个任务本身都是一个小程序。它有一个入口点,通常在无限循环中永远运行&#…

回归测试选择用例,看这里就可以了。

介绍 在软件生命周期中,软件经常发生变化,软件开发人员任何代码改动都会有引入故障的风险)。 为了消除或减小这种风险,在软件迭代开发模式下,回归测试扮演着重要的角色:它能够帮助测试人员验证新增的功能…

mac配置jdk环境变量

**下载完成后直接安装一路next直到完成。 查看JDK安装后的路径 在终端输入以下命令查看JDK地址** 按照以下命令的顺序来设置jdk环境变量 查看JDK地址 :/usr/libexec/java_home -V。 open -e .bash_profile打开文件 touch .bash_profile 创建文件 打开.bash_prof…

G2O (General Graph Optimization)入门及简单使用

g2o全称是General Graph Optimization,也就是图优化,我们在做SLAM后端或者更加常见的任何优化问题(曲线拟合)都可以使用G2O进行处理。 先放出本文的几个参考链接: 半闲居士(高翔博士) 非线性…

智能终端信息安全概念(一):开篇

最近屁事以及自己对于时间的把控太差了,还有就是一个师妹最近让辅导作业,很烦。 回归正轨,好好学习Linux驱动的方面。 在实际的Linux驱动中,Linux内核尽量做得更多,以便于底层的驱动可以做得更少。 而且&#xff0c…

【C++笔试强训】第十七天

🎇C笔试强训 博客主页:一起去看日落吗分享博主的C刷题日常,大家一起学习博主的能力有限,出现错误希望大家不吝赐教分享给大家一句我很喜欢的话:夜色难免微凉,前方必有曙光 🌞。 💦&a…

【微服务容器化】第四章-Docker应用部署

🌴第四章 Docker应用部署🍃4.1 Mysql部署🍃4.2 Tomcat部署🍃4.3 Nginx 部署🍃4.4 redis 部署🍃4.1 Mysql部署 分析: 容器内的网络服务和外部机器不能直接通信 外部机器和宿主机可以直接通信 宿主机和容器…

因为有了它,我用舍友玩王者的时间拿到了华为offer

随时随地刷Leetcode题的方法,大学因为这个,我入职大厂! 下面有免费试用网址 目录我如何拿到大厂offer秘密武器使用教程VSCODE云IDE介绍完整功能,兼容VS Code安装的插件没有效果?通过终端启动项目后无法预览?CIDE收费…

sklearn笔记:调参

1 介绍 超参数是不直接在估计器中学习的参数。 在 scikit-learn 中,它们作为参数传递给估计器类的构造函数。 需要搜索超参数空间以获得最佳交叉验证分数。scikit-learn 中提供了两种通用的参数搜索方法: 对于给定的值,GridSearchCV 会详尽地…

客快物流大数据项目(八十四):Impala优化

文章目录 Impala优化 一、​​​​​​​Impala关键配置 二、Impala查询分析

C++ Reference: Standard C++ Library reference: C Library: cstring: strspn

C官网参考链接&#xff1a;strspnhttps://cplusplus.com/reference/cstring/strspn/strspn 函数 <cstring> strspn size_t strspn ( const char * str1, const char * str2 ); 获取字符串中字符集的跨度 返回str1的初始部分的长度&#xff0c;它只包含str2的一部分字符…