🫐变量
1、系统变量
- 系统变量:变量由系统提供,不是用户定义的,属于服务器层面的,根据作用域的不同分为:全局变量、会话变量
- 查看所有的系统变量
show global variables;
show [session] variables;
- 查看满足条件的部分系统变量
show [session]|global variables like '%char%';
- 查看指定的某个系统变量的值
select @@global | [session]. 系统变量名
#例子
select @@transaction_isolation;
- 为某个系统变量赋值
# 方式一:
set global | [session] 变量名= 值;
#方式二:
set @@global | [session] .变量名=值;
- 全局变量的作用域:服务器每次启动将会为所有的全局变量赋初始值,针对与所有的会话(连接)都有效。
- 会话变量的作用域:仅仅针对当前的会话(连接)有效
2、自定义变量
- 自定义变量:用户变量、局部变量
- 步骤:声明、赋值、使用(查看、比较、运算等)
- 用户变量:针对当前会话(连接)有效,同于会话变量的作用域
1>用户变量在声明时必须初始化
# 声明并初始化:三种方式
set @用户变量名= 值;
set @用户变量名:= 值;
select @用户变量名:= 值;
2>赋值(更新用户变量的值)
# 方式一:通过set或者select
set @用户变量名= 值;
set @用户变量名:= 值;
select @用户变量名:= 值;
#方式二: 通过select into
select 字段 into 用户变量名
from 表;
#上面的字段只能是一个值
3>使用
select @用户变量名;
- 用户变量可以使用在任何地方,也就是begin end里面,或者外面
- 局部变量:仅仅在定义它的begin end中有效,且必须放在begin end的第一句话
1> 声明
Declare 变量名 类型;
declare 变量名 类型 default 类型
2>赋值
赋值(更新局部变量的值)
# 方式一:通过set或者select
set 局部变量名= 值;
set 局部变量名:= 值;
select @局部变量名:= 值;
#方式二: 通过select into
select 字段 into 局部变量名
from 表;
#上面的字段只能是一个值
3>使用
select 局部变量;
🍑存储过程
- 存储过程是一组预先编译好的sql语句的集合
- 特点:提高代码的重用性;简化操作;减少了编译次数并且减少了和数据库服务器的连接次数,提高了效率
- 创建语法
create procedure 存储过程名(参数列表)
begin
存储过程体(一组合法的sql语句)
end
参数列表包含三个部分:参数模式-参数名-参数类型
- 参数模式:
in:该参数可以作为输入,也就是该参数需要调用方传入值
out:该参数可以作为输出,也就是该参数可以作为返回值
inout:该参数既可以作为输入也可以作为输出,也就是该参数既需要传入值,也可以返回值 - 如果存储过程的方法体仅仅只有一句话,则begin end可以省略
存储过程体中的每条sql语句的结尾要求必须加分号
存储过程的结尾标识符可以使用delimiter重新设置
delimiter 结束标记
- 调用语法
call 存储过程名(实参列表);
- 例子
delimiter $
create procedure 存储过程名(参数列表)
begin
一组sql语句;
end $
#调用的时候
call 存储过程名(参数列表) $
#这里应该使用为存储过程定义的结束符
- 删除存储过程
drop procedure 存储过程名
- 查看存储过程的结构
show create procedure 存储结构名;
🍊函数
- 与存储过程的不同:存储过程可以有0个或多个返回值,适合做批量插入、批量更新;函数有且仅有一个返回值,适合进行数据处理后返回一个结果
- 语法:
create function 函数名(参数列表) returns 返回值类型
begin
函数体
end
参数列表包含两个部分:参数名 参数类型
函数体内一定有return语句,如果没有会报错
函数体中只有一句话时,可以省略begin end
同样要使用delimiter语句设置结束标记
- 调用
select 函数名(参数列表)
- 例子:
# 返回公司的员工个数
delimiter $
create function countNum() returns int
begin
declare res int default 0;
select count(*) into res
from employees;
return res;
end $
select countNum()$
- 查看函数的结构
show create 函数名;
- 删除函数
drop function 函数名;