广告
返回顶部
首页 > 资讯 > 数据库 >Mysql存储过程有什么作用?如何使用存储过程?
  • 675
分享到

Mysql存储过程有什么作用?如何使用存储过程?

2024-04-02 19:04:59 675人浏览 八月长安
摘要

Mysql自5.0起就支持存储过程,存储过程通俗的讲就是在一段封装过的sql,但不仅仅只有SQL那么简单,通常还会有变量、条件判断、循环体,游标等。存储过程的作用在很多场景中,需要将多个表的数据处理,来产生

Mysql自5.0起就支持存储过程,存储过程通俗的讲就是在一段封装过的sql,但不仅仅只有SQL那么简单,通常还会有变量、条件判断、循环体,游标等。

存储过程的作用

在很多场景中,需要将多个表的数据处理,来产生新的我们需要的数据。这些多个表的数据并不能通过连接等查询方式给出,只能通过判断和循环才能产生。这个时候,就可以利用存储过程来实现。

此外,存储过程还有一些好处,比如性能比较高,还有能减少网络请求。如果不用存储过程来实现的话,使用PHP来实现就需要调用多次mysql,产生多次请求。

当然,存储过程也不是没有缺点的,它比较哪调式,另外不支持集群

创建存储过程

创建存储过程语法如下:

CREATE PROCEDURE 过程名(参数) 
BEGIN
 过程体
END

关于参数,设置参数语法为

[IN|OUT|INOUT] 参数名 类型

  • IN 表示该变量只能在过程体内使用

  • OUT 表示该变量只能在过程体外使用

  • INOUT 表示在过程体内和体外都能使用

下面,我们来创建一个最简单的存储过程。

CREATE PROCEDURE p1(IN x INT) 
BEGIN
  SELECT x;
END;

变量

在MySQL中变量分为全局变量和局部变量。

全局变量以@开头,无需声明,直接使用即可,如

SET @name='gwx';

局部变量需要先声明,局部变量的初始化方法如下:

DECLARE x int DEFAULT 0;

下面我们来完成一个存储过程:根据路程计算车费,3公里内按6远计算,超过的距离按每公里1.2元计算.

-- distance 路程
CREATE PROCEDURE p1(in distance FLOAT)
BEGIN
  DECLARE d_money FLOAT DEFAULT 0; 
    IF distance>3 THEN 
       SET d_money=6+(distance-3)*1.2;
    ELSE
      SET d_money=6;
    END IF;
    SELECT d_money;
END;

游标

php做比较,游标有点想foreach,每次循环获取一条记录。

定义一个游标:

declare 游标名 CURSOR FOR SELECT 语句

开启关闭游标:

  • open 游标名

  • close 游标名

取游标数据:

FETCH 游标名 INTO 变量名

可以这么简单的介绍,大家会有疑惑,不清楚应该如何去使用。下面,来看一个实例,从实例中学习如何使用游标。

用游标完成一个非常简单的功能,将test_cursor表中数字全部累加起来。

CREATE TABLE IF NOT EXISTS test_cursor(
  num1 INT(10) UNSIGNED NOT NULL DEFAULT 0,
  num2 INT(10) UNSIGNED NOT NULL DEFAULT 0
);    
INSERT INTO test_cursor(num1,num2) VALUES(1,1),(2,2),(3,3);
 
CREATE PROCEDURE `test_cursor`()
BEGIN
    DECLARE sum INT(10) DEFAULT 0;
    DECLARE n1,n2 INT(10);
    DECLARE done INT DEFAULT 0;
    
    DECLARE cur CURSOR FOR SELECT num1,num2 FROM test_cursor; 
    DECLARE CONTINUE HANDLER FOR SQLSTATE '02000' SET done=1; 
    
    OPEN cur; -- 打开游标
    WHILE done=0 DO      
        FETCH cur INTO n1,n2;
        
        IF done=0 THEN -- 注意这里为什么加IF条件,不加的话,最后一个值会被多加一遍         
      SET sum=sum+n1+n2;
        END IF;
    END WHILE;
    CLOSE cur;  -- 关闭游标
    
    SELECT sum;
END

这里有几点需要注意,首先局部变量的定义必须要在声明游标前声明。

另外,这里DECLARE CONTINUE HANDLER FOR SQLSTATE '02000' SET done=1; 表示游标结束后将done设置为1,以结束循环。

以上就是Mysql存储过程应用的详细内容,更多请关注编程网其它相关文章!

您可能感兴趣的文档:

--结束END--

本文标题: Mysql存储过程有什么作用?如何使用存储过程?

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

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

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

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

下载Word文档
猜你喜欢
  • Mysql存储过程有什么作用?如何使用存储过程?
    Mysql自5.0起就支持存储过程,存储过程通俗的讲就是在一段封装过的SQL,但不仅仅只有SQL那么简单,通常还会有变量、条件判断、循环体,游标等。存储过程的作用在很多场景中,需要将多个表的数据处理,来产生...
    99+
    2022-10-18
  • MySQL存储过程有什么用
    这篇文章主要介绍MySQL存储过程有什么用,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完! 1.      存储过程简介 我们常用...
    99+
    2022-10-19
  • mysql存储过程的作用是什么
    本篇内容主要讲解“mysql存储过程的作用是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“mysql存储过程的作用是什么”吧! ...
    99+
    2023-04-19
    mysql
  • mysql存储过程的游标有什么作用
    这篇文章主要讲解了“mysql存储过程的游标有什么作用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“mysql存储过程的游标有什么作用”吧! ...
    99+
    2022-10-19
  • mysql使用存储过程的作用有哪些
    这篇文章将为大家详细讲解有关mysql使用存储过程的作用有哪些,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。mysql使用存储过程的作用:1、增强SQL语句的功能和灵活性...
    99+
    2022-10-18
  • php+mysql如何使用存储过程
    这篇文章主要介绍“php+mysql如何使用存储过程”,在日常操作中,相信很多人在php+mysql如何使用存储过程问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”php+my...
    99+
    2023-04-19
    mysql php
  • MySQL中如何使用存储过程
    这篇文章将为大家详细讲解有关MySQL中如何使用存储过程,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。 使用CallableStatemen...
    99+
    2022-10-18
  • sql存储过程有什么用
    小编给大家分享一下sql存储过程有什么用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!sql存储过程是可编程函数,在数据库中创建...
    99+
    2022-10-18
  • mysql有存储过程吗
    这篇文章主要介绍“mysql有存储过程吗”,在日常操作中,相信很多人在mysql有存储过程吗问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”mysql有存储过程吗”的疑惑有所帮...
    99+
    2022-10-19
  • mysql存储过程是什么
    这篇文章给大家分享的是有关mysql存储过程是什么的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。一、定义存储过程(Stored Procedure)是在大型数据库系统中,一组为了...
    99+
    2022-10-19
  • mysql存储过程有什么优点
    本篇内容主要讲解“mysql存储过程有什么优点”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“mysql存储过程有什么优点”吧!在mysql中,存储过程是一组为了...
    99+
    2022-10-18
  • mysql如何调用存储过程
    在MySQL中调用存储过程可以使用CALL语句。语法如下:```CALL procedure_name([parameter1, parameter2, ...]);```其中,procedure_name是存储过程的名称,parame...
    99+
    2023-08-11
    mysql
  • MySQL中怎么使用存储过程
    MySQL中怎么使用存储过程,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。 mysql存储过程存储过程(Stored  P...
    99+
    2022-10-18
  • MySQL存储过程理解和作用
    存储过程是存储在数据库目录中的一段声明性SQL语句。方便其他应用程序可以调用存储过程。 储存器的作用 1, 通常存储过程有助于提高应用程序的性能。 2,存储过程有助于减少应用程序和数据库服务器之间的流...
    99+
    2022-10-18
  • 如何在mysql中使用存储过程
    如何在mysql中使用存储过程?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。存储过程包含了一系列可执行的sql语句,存储过程存放于MySQL中...
    99+
    2022-10-18
  • mysql存储过程有什么优缺点
    这篇文章主要介绍“mysql存储过程有什么优缺点”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“mysql存储过程有什么优缺点”文章能帮助大家解决问题。 ...
    99+
    2022-10-19
  • PHP如何调用MySQL存储过程
    这篇文章主要介绍了PHP如何调用MySQL存储过程的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇PHP如何调用MySQL存储过程文章都会有所收获,下面我们一起来看看吧。 ...
    99+
    2023-04-21
    php mysql
  • mysql 中如何调用存储过程
    mysql 中如何调用存储过程,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。  MySQL调用存储过程必须要使用call语句调...
    99+
    2022-10-18
  • mysql中如何调用存储过程
    这篇文章主要讲解了“mysql中如何调用存储过程”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“mysql中如何调用存储过程”吧! ...
    99+
    2022-10-19
  • mybatis如何调用mysql存储过程
    这篇“mybatis如何调用mysql存储过程”除了程序员外大部分人都不太理解,今天小编为了让大家更加理解“mybatis如何调用mysql存储过程”,给大家总结了以下内容,具有一定借鉴价值,内容详细步骤清晰,细节处理妥当,希望大家通过这篇...
    99+
    2023-06-26
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作