IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> MySQL变量的应用 -> 正文阅读

[大数据]MySQL变量的应用

写在前面

数据库脚本开发过程,除基本的查询增、删、改、查外,为了更方便于应用,编写更复杂的逻辑,常用的方法还有变量,临时表等。特别是在开发存储过程和函数时。
本文只会对变量进行实际应用的描述。

1.变量

MySQL中变量分为:局部变量,用户变量,会话变量和全局变量。

  1. 局部变量,在写存储过程或函数时,只在脚本的begin/end语句模块中使用的变量。
  2. 用户变量,无需声明,直接使用。
  3. 会话变量就是在客户端建立连接时建立的变量,随着会话的结束,变量也同时消亡。会话变量的变化只影响到当前所建立的会话,即只是在当前客户端可用。
  4. 全局变量是会对于整个数据库的,他不会随着某一客户端的建立和消亡而变化。全局变量的修改会影响到所有会话和客户端,即在连接客户端时的默认值。

1.1 查看会话变量和全局变量

会话变量和全局变量为系统层面的变量,可理解为系统配置项。

1.1.1 会话变量

-- 会话变量 --
# 查看会话变量
show session variables;

# 模糊查看指定会话变量
show session variables like 'auto%';  # 查看auto开头的变量

# 查询会话变量值
select @@session.autocommit;  # 查询会话变量autocommit的值

# 修改变量
# 自动提交功能如果关闭,在执行数据表修改操作后,需要再执行commit;命令修改才会生效。
set @@session.autocommit=0;  # 通过修改变量来关闭会对于本次会话的自动提交功能

1.1.2 全局变量

-- 全局变量 --
# 查看全局变量
show global variables;

# 模糊查看指定全局变量
show global variables like 'auto%';  # 查看auto开头的变量

# 查询全局变量值
select @@global.autocommit;  # 查询全局变量autocommit的值

# 修改变量
# 自动提交功能如果关闭,在执行数据表修改操作后,需要再执行commit;命令修改才会生效。
set @@global.autocommit=0;  # 通过修改变量来关闭数据库的自动提交功能

1.2 创建局部变量和用户变量

1.2.1 变量类型

数据库中常用的类型有:

字符型:varchar
整型:int / integer
长整型:long
数字型:numeric
双精度型:double
日期时间型:datetime
时间戳:timestamp

声明变量格式为:

DECLARE 变量名 变量类型 [DEFAULT 预设值]

1.2.2 局部变量

通过【Navicat for MySQL】客户端创建存储过程时,代码中会自动生成一对BEGIN/END,表示一个SQL脚本域。

BEGIN
	#Routine body goes here...

END;

声名变量需要在通过关键字declare来标识。变量的使用参考脚本:

BEGIN
	#Routine body goes here...
	# 定义变量 Total_Row_Count 并设置预设为0
	DECLARE Total_Row_Count INT DEFAULT 0;

	# 给变量赋值为 1
	SET Total_Row_Count := 1;

	# 通过 SELECT 输出变量的值
	SELECT Total_Row_Count;

	# 通过查询数据表,把查询结果赋值给变量
	SELECT Count(*) INTO Total_Row_Count
	FROM country;

	# 通过 SELECT 输出变量的值
	SELECT Total_Row_Count;

END

运行结果:
在这里插入图片描述
在这里插入图片描述

1.2.3 用户变量

用户变量赋值的格式是:SET @i = 0

# 用户变量无需提前声明
# 赋值用户变量@i初始值为0
SET @i = 0;

# 通过用户变量生成序号
SELECT
	@i :=@i + 1 AS `ID`,
	`Code`,
	`Name`,
	`Continent`
FROM
	country;

执行结果如下所示:
在这里插入图片描述

1.2.4 参数

使用存储过程或函数,参数是非常常用的一个功能。
存储过程的DDL(数据库定义语言),存储过程通过参数vContinent,lPopulation将调用时的两个数值传给存储过程进行查询操作。

修饰词IN
输入参数

CREATE PROCEDURE `sp_get_countrys`(IN `vContinent` varchar(30),IN `lPopulation` long)
BEGIN
	#Routine body goes here...

	SELECT *
	FROM country
  WHERE `Continent` = vContinent And `Population` > lPopulation
;
END

通过 **SQL(结构化查询语言)**调用存储过程

Call sp_get_countrys('Asia', 100000000);

可以看到结果是把输入参数作为条件进行的查询
在这里插入图片描述

修饰词OUT
输出参数,此参数需要指定一个变量,变量不需初始化,用来接收运行的输出结果。
修改上述脚本,增加一个输出变量,vCount用于返回查询到的记录结果数量

CREATE PROCEDURE `sp_get_countrys`(IN `vContinent` varchar(30),IN `lPopulation` long,OUT `vCount` long)
BEGIN
	#Routine body goes here...

	SELECT *
	FROM country
  WHERE `Continent` = vContinent And `Population` > lPopulation
;

	SELECT COUNT(*) INTO vCount
	FROM country
  WHERE `Continent` = vContinent And `Population` > lPopulation
;
	
END

使用如下脚本调用存储过程,并通过用户变量@CountryCount来接收输出变量的结果

Call sp_get_countrys('Asia',10000000,@CountryCount);
select @CountryCount;

可以查询结果将变成两个结果输出。

结果1 为数据结果
结果2 为OUT变量的输出结果,查询数据结果数量
在这里插入图片描述

2 总结

变量类似于高级开发语言如JAVA、C#、VB等,只要是编程语言都是一项最基本的入门必学的知识,存储过程或函数开发过程中也同样是一项不可缺少的知识。每个想成为码农的有志小青年,都应该牢牢的把这项知识掌握到位。


就让我们一起

努力,奋斗,内卷吧!

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2022-07-20 18:56:33  更:2022-07-20 18:58:42 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/20 1:36:04-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码