存储过程与函数
类似与Java的方法和C语言的函数
存储过程概述
含义
一组经过 预先编译的SQL语句的封装
执行过程:存储过程预先存储在MySQL服务器上,客户端发出命令后,服务器可以把预先存储好的SQL语句全部执行
好处
- 简化操作,提高了SQL语句的通用性,减少开发程序员的压力
- 减少操作失误,提高效率
[En]
reduce operational errors and improve efficiency*
- 减少网络传输量
- 减少SQL语句暴露在网上的风险,提高了安全性
与视图、函数的对比
分类
- 没有参数(无参无返回)
- 仅仅有带IN类型(有参无返回)
- 仅仅有带OUT类型(无参有返回)
- 既带IN又带OUT类型(有参有返回)
- 带INOUT类型(有参有返回)
IN、OUT、INOUT都可以在一个存储过程中带多个
创建存储过程
语法分析
DELIMITER $ #以$作为结束符(相当于;的作用,存储过程体中有;会影响)
CREATE PROCEDURE 存储过程名(IN|OUT|INOUT 参数名 参数类型)
[characteristics...]
BEGIN
存储过程体;
END $
DELIMITER ; #还原以;为结束符
代码举例
无参与返回值
提起创建好数据库和表
#创建
DELIMITER $
CREATE procedure select_all_data()
begin
select *
from employees;
end $
DELIMITER ;
创建成功
#调用
CALL select_all_data();
无参有返回值(OUT)
#创建
DELIMITER $ #返回工资最低的员工
create procedure show_min_salary(OUT ms double)
begin
select min(salary) into ms #将min的工资给了ms
from employees;
end $
DELIMITER ;
#调用
CALL show_min_salary(@ms);
#查看变量值
SELECT @ms;
有参无返回值(IN)
DELIMITER $ #查看表中某个员工的工资,用IN输入员工名字
create procedure show_someone_salary(IN empname varchar(15))
begin
select salary
from employees
where last_name = empname;#传入的名字等于表中的名字
end $
DELIMITER ;
#调用
1.
CALL show_someone_salary('Abel');
2.
SET @empname := 'Abel';
CALL show_someone_salary(@empname);
有参有返回值(IN和OUT)
DELIMITER $ #查看表中某个员工的工资,用IN输入员工名字,用OUT输出
create procedure show_someone_salary2(IN empname varchar(15),OUT empsalary double)
begin
select salary into empsalary
from employees
where last_name = empname;
end $
DELIMITER ;
#调用
SET @empname := 'Abel'
CALL show_someone_salary(@empname,@empsalary);
#查看
select @empsalary;
有参有返回值(INOUT)
DELIMITER $ #查询某个员工领导的姓名,并用INOUT"empname"输入员工的名字,输出领导的名字
create procedure show_mgr_name(INout empname varchar(20))
begin
select t1.last_name into empname
FROM employees t1
where t1.employe_id = (select t2.manger_id
from employees t2
WHERE t2.last_name = empname;
);
end $
DELIMITER ;
#调用
SET @empname :='Abel';
CALL show_mgr_name(@empname);#体现IN
#查看
select @empname;#体现OUT
如何调试
循序渐进(一句一句)
[En]
Advance step by step (sentence by sentence)
存储函数的使用
系自定义的函数
语法分析
DELIMITER $
CREATE FUNCTION 函数名(参数名 参数类型)
RETURNS 返回值类型
[characteristics...]
BEGIN
函数体; #一定有return语句
END $
DELIMITER ;
- 只有IN类型(多进一出)
- return的类型要和返回值的类型一样
代码举例
无参
mysql>SET GLOBAL log_bin_trust_function_creators = 1;#防止报错
#声明
DELIMITER $#查Abel的邮箱
CREATE FUNCTION email_by_name()
RETURNS carchar(20)
BEGIN
return(select email
from employees
where name = 'Abel'
);
END $
DELIMITER ;
#调用
EXISTS email_by_name();
有参
#参数传入emp_id,查询emp_id的email
#声明
DELIMITER $
CREATE FUNCTION email_by_id(emp_id int)
RETURNS carchar(20)
BEGIN
return(select email
from employees
where employe_id = emp_id
);
END $
DELIMITER ;
#调用
1.
EXISTS email_by_id('101');
2.
set @emp_id := '101';
EXISTS email_by_id(@emp_id);
#参数传入dept_id,查询该id部门的员工人数
#声明
DELIMITER $
CREATE FUNCTION count_by_id(dept_id int)
RETURNS int
BEGIN
return(select count(*)
from employees
where department_id = dept_id
);
END $
DELIMITER ;
#调用
set @dept_id = 30;
EXISTS count_by_id(@dept_id);
对比存储函数和存储过程
存储函数可以在查询语句中使用,但存储过程不能
[En]
Stored functions can be used in query statements, but stored procedures cannot
存储过程功能更强大,包括执行表操作和事务操作的能力,而这些功能是函数所不具备的
[En]
Stored procedures are more powerful, including the ability to perform table operations and transaction operations, which functions do not have
存储过程和函数的查看、修改、删除
查看
创建完成后,如何知道我们创建的存储过程和存储函数是否成功?
[En]
After the creation is completed, how do we know whether the stored procedures and stored functions we created are successful?
- 使用 SHOW CREATE 语句
SHOW CREATE PROCEDURE 存储过程\G
SHOW CREATE FUNCTION 函数名字\G
#\G在命令行中可以运行,若是MySQLbu不支持不支持,就用;
- 使用SHOW STATUS 语句
SHOW PROCEDURE STATUS LIKE '存储过程名'\G
SHOW FUNCTION STATUS LIKE '函数名字'\G
#\G在命令行中可以运行,若是MySQLbu不支持不支持,就用;
- 从information_schema.Routines表中查看
SELECT * FROM information_schema.Routines
WHERE ROUTINE_NAME = '存储过程名' (AND ROUTINE_TYPE ='PROCEDURE')\G
SELECT * FROM information_schema.Routines
WHERE ROUTINE_NAME = '函数名字' (AND ROUTINE_TYPE ='FUNCTION')\G
#\G在命令行中可以运行,若是MySQLbu不支持不支持,就用;
#若存储过程含函数重名,则写AND ROUTINE_TYPE ='类型'
查询效果
修改
修改存储过程或函数,不影响存储过程或函数的功能( 不改存储过程\函数体),只是修改相关特性,使用 ALTER 语句实现
ALTER {PROCEDURE | FUNCTION} 存储过程\函数名 [characteristic...];
删除
使用 DROP 语句
DROP {PROCEDURE | FUNCTION} [IF EXISTS] 存储过程\函数名;
关于存储过程和函数的争议
合法的公司需要对大型项目使用存储过程函数,而一些公司则禁止使用
[En]
Valid companies need to use stored procedures functions for large projects, while some companies prohibit using
优点
- 存储过程\函数可以一次编译多次使用
- 减少开发工作量(代码打包成块,可重用)
[En]
reduce the workload of development (the code is packaged into blocks and can be reused)*
- 提供良好的封装性
- 提供良好的安全性(可设置权限)
[En]
provide good security (permissions can be set)*
- 减少网络传输
缺点
- 可移植性差
- 调试难度大(有第三方调试,但收费)
[En]
difficult to debug (there is a third party for debugging, but there is a charge)*
- 存储过程\函数版本管理困难
- 不适合高并发的场景
Original: https://www.cnblogs.com/wht-de-bk/p/16022288.html
Author: T,a,o
Title: MySQL存储过程和函数
原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/505550/
转载文章受原作者版权保护。转载请注明原作者出处!