iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >MySQL存储过程和函数
  • 609
分享到

MySQL存储过程和函数

MySQL存储过程和函数 2020-11-16 11:11:22 609人浏览 猪猪侠
摘要

存储过程与函数 类似与Java的方法和C语言的函数 存储过程概述 含义 一组经过预先编译的sql语句的封装 执行过程:存储过程预先存储在Mysql服务器上,客户端发出命令后,服务器可以把预先存储好的SQL语句全部执行 好处 简化操作,提

MySQL存储过程和函数

存储过程与函数

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

存储过程概述

含义

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

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

好处

  • 简化操作,提高了SQL语句的通用性,减少开发程序员的压力
  • 减少操作中的失误,提高效率
  • 减少网络传输量
  • 减少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 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 ;

  • 只有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);

对比存储函数和存储过程

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

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

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

查看

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

  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

您可能感兴趣的文档:

--结束END--

本文标题: MySQL存储过程和函数

本文链接: https://www.lsjlt.com/news/9207.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 浅谈MYSQL存储过程和存储函数
    目录1. 什么是存储过程和存储函数?2. 创建存储过程3. 创建存储函数4. 存储过程和存储函数的使用5. 带有if语句的存储过程6. 带有循环语句的存储过程7. 带有事务的存储过程8. 带有游标的存储函数9. 存储过程...
    99+
    2023-05-05
    MYSQL存储过程 MYSQL 存储函数
  • 细谈Mysql的存储过程和存储函数
    1 存储过程 1.1 什么是存储过程 存储过程是一组为了完成某项特定功能的sql语句集,其实质上就是一段存储在数据库中的代码,他可以由声明式的sql语句(如CREATE,UPDATE,SELECT等语句...
    99+
    2024-04-02
  • mysql存储过程和存储函数有哪些区别
    本文小编为大家详细介绍“mysql存储过程和存储函数有哪些区别”,内容详细,步骤清晰,细节处理妥当,希望这篇“mysql存储过程和存储函数有哪些区别”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起...
    99+
    2024-04-02
  • mysql存储过程和函数的区别
    存储过程与函数的区别:存储过程可返回多个值或结果集,而函数仅返回单个标量值。存储过程通常在事务中执行,而函数可独立执行。存储过程具有副作用,而函数通常没有。存储过程可重用,但函数通常比存...
    99+
    2024-04-22
    mysql
  • MySQL中存储过程和存储函数的示例分析
    这篇文章主要为大家展示了“MySQL中存储过程和存储函数的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“MySQL中存储过程和存储函数的示例分析”这篇文...
    99+
    2024-04-02
  • MYSQL中存储过程和函数怎么写
    这篇文章将为大家详细讲解有关MYSQL中存储过程和函数怎么写,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。什么是存储过程简单的说,就是一组SQL语句集,功能强大,可以实现...
    99+
    2024-04-02
  • mysql中存储过程和存储函数指的是什么
    小编给大家分享一下mysql中存储过程和存储函数指的是什么,希望大家阅读完这篇文章后大所收获,下面让我们一起去探讨吧!在mysql中,存储过程和存储函数都是数据库中定义的一些SQL语句的集合。其中,存储函数...
    99+
    2024-04-02
  • MySQL 视图、函数和存储过程详解
    目录一、视图二、函数三、存储过程MySQL 是一种流行的关系型数据库管理系统,其具有强大的功能和灵活性,使其成为了许多企业和个人喜爱的数据库选择。在 MySQL 中,视图、函数和存储...
    99+
    2023-05-18
    MySQL 视图 函数和存储过程 MySQL 函数和存储过程
  • MySQL 视图、函数和存储过程详解
    目录一、视图二、函数三、存储过程mysql 是一种流行的关系型数据库管理系统,其具有强大的功能和灵活性,使其成为了许多企业和个人喜爱的数据库选择。在 MySQL 中,视图、函数和存储过程是常见的数据库对象,它们都有助于提...
    99+
    2023-04-26
    MySQL 视图 函数和存储过程 MySQL 函数和存储过程
  • MySQL存储过程和函数怎么创建
    这篇文章主要介绍“MySQL存储过程和函数怎么创建”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“MySQL存储过程和函数怎么创建”文章能帮助大家解决问题。1.0  创建存储过程和函数创建存...
    99+
    2023-06-30
  • 彻底搞懂MySQL存储过程和函数
    目录1.0  创建存储过程和函数1. 创建存储过程2. 创建存储函数2|0变量1. 定义变量2. 变量赋值3|0定义条件和处理程序1. 定义条件2. 定义处理程序4|0光标...
    99+
    2024-04-02
  • 关于MySQL的存储过程与存储函数
    目录初识存储过程存储过程语法存储过程调用存储函数的使用语法函数的调用对比存储函数和存储过程初识存储过程 理解:含义: 存储过程(Stored Procedure)是在大型数据库系统中...
    99+
    2023-05-19
    MySQL存储过程 MySQL存储函数
  • mysql存储过程和函数有什么区别
    存储过程和函数的区别:用途:存储过程用于复杂操作,函数用于单次计算。语法:存储过程使用 create procedure 创建,函数使用 create function 创建。输入输出:...
    99+
    2024-04-22
    mysql
  • mysql存储过程与存储函数实例分析
    这篇文章主要介绍了mysql存储过程与存储函数实例分析的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇mysql存储过程与存储函数实例分析文章都会有所收获,下面我们一起来看看吧。...
    99+
    2022-11-30
    mysql
  • 如何在MySQL中使用存储过程和函数?
    如何在MySQL中使用存储过程和函数?在MySQL中,存储过程和函数是被封装的一组SQL语句,可以被重复调用。存储过程是一组可以在服务器上执行的SQL语句集合,而函数则是一个独立的且可重用的代码块。两者的不同之处在于,存储过程可以返回多个结...
    99+
    2023-10-22
    函数 MySQL 存储过程
  • MySQL之存储过程和函数的示例分析
    这篇文章将为大家详细讲解有关MySQL之存储过程和函数的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。一、变量系统变量系统变量分为全局变量和会话变量,是由系统提供...
    99+
    2024-04-02
  • mysql存储过程与函数的写法
    本篇内容介绍了“mysql存储过程与函数的写法”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! 存...
    99+
    2024-04-02
  • Oracle中怎么创建存储过程和存储函数
    本篇文章为大家展示了Oracle中怎么创建存储过程和存储函数,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。select * from emp;------...
    99+
    2024-04-02
  • MySQL存储过程详解 mysql 存储过程
    mysql存储过程详解 1.      存储过程简介   我们常用的操作数据库语言SQL语句在执行的时候需要要先编译,然后执行,而存储过程(Stored Proce...
    99+
    2024-04-02
  • mysql存储过程与存储函数的区别有哪些
    这篇文章主要讲解了“mysql存储过程与存储函数的区别有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“mysql存储过程与存储函数的区别有哪些”吧! ...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作