文章详情

短信预约信息系统项目管理师 报名、考试、查分时间动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

MySQL存储过程和函数

2020-11-16 11:06

关注

MySQL存储过程和函数

类似与Java的方法和C语言的函数

存储过程概述

含义

一组经过预先编译的SQL语句的封装

执行过程:存储过程预先存储在MySQL服务器上,客户端发出命令后,服务器可以把预先存储好的SQL语句全部执行

好处

与视图、函数的对比

分类

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 t3
      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

如何调试

逐步推进(一句一句的看)

存储函数的使用

系自定义的函数

语法分析

DELIMITER $
CREATE FUNCTION 函数名(参数名 参数类型)
RETURNS 返回值类型
[characteristics...]
BEGIN 
     函数体; #一定有return语句
END $
DELIMITER ;

代码举例

无参

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);

对比存储函数和存储过程

存储函数可以放在查询语句中使用,存储过程不可以

存储过程功能更强大,包括可以执行对表的操作和事务操作,这些是函数不具备的

存储过程和函数的查看、修改、删除

查看

创建完成之后,怎么知道我们创建的存储过程、存储函数是否成功呢

  1. 使用 SHOW CREATE 语句
SHOW CREATE PROCEDURE 存储过程G

SHOW CREATE FUNCTION 函数名字G
#G在命令行中可以运行,若是MySQLbu不支持不支持,就用;
  1. 使用SHOW STATUS 语句
SHOW PROCEDURE STATUS LIKE "存储过程名"G

SHOW FUNCTION STATUS LIKE "函数名字"G
#G在命令行中可以运行,若是MySQLbu不支持不支持,就用;
  1. 从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] 存储过程函数名;

关于存储过程和函数的争议

有效公司对于大型项目需要使用存储过程函数,而有的公司禁止使用

优点

缺点

原文地址:https://www.cnblogs.com/wht-de-bk/archive/2022/03/18/16022288.html

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯