写在前面
数据库脚本开发过程,除基本的查询增、删、改、查外,为了更方便于应用,编写更复杂的逻辑,常用的方法还有变量,临时表等。特别是在开发存储过程和函数时。 本文只会对变量进行实际应用的描述。
1.变量
MySQL中变量分为:局部变量,用户变量,会话变量和全局变量。
- 局部变量,在写存储过程或函数时,只在脚本的begin/end语句模块中使用的变量。
- 用户变量,无需声明,直接使用。
- 会话变量就是在客户端建立连接时建立的变量,随着会话的结束,变量也同时消亡。会话变量的变化只影响到当前所建立的会话,即只是在当前客户端可用。
- 全局变量是会对于整个数据库的,他不会随着某一客户端的建立和消亡而变化。全局变量的修改会影响到所有会话和客户端,即在连接客户端时的默认值。
1.1 查看会话变量和全局变量
会话变量和全局变量为系统层面的变量,可理解为系统配置项。
1.1.1 会话变量
show session variables;
show session variables like 'auto%';
select @@session.autocommit;
set @@session.autocommit=0;
1.1.2 全局变量
show global variables;
show global variables like 'auto%';
select @@global.autocommit;
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
END;
声名变量需要在通过关键字declare来标识。变量的使用参考脚本:
BEGIN
DECLARE Total_Row_Count INT DEFAULT 0;
SET Total_Row_Count := 1;
SELECT Total_Row_Count;
SELECT Count(*) INTO Total_Row_Count
FROM country;
SELECT Total_Row_Count;
END
运行结果:
1.2.3 用户变量
用户变量赋值的格式是:SET @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
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
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等,只要是编程语言都是一项最基本的入门必学的知识,存储过程或函数开发过程中也同样是一项不可缺少的知识。每个想成为码农的有志小青年,都应该牢牢的把这项知识掌握到位。
就让我们一起
努力,奋斗,内卷吧!
|