原文来自

https://godruoyi.com/artiles/...

这个可以作为mySql的存储过程的入门资料。

存储过程简单来说,就是为以后的使用而保存的一条或多条MySQL语句的集合。可将其视为批件,虽然它们的作用不仅限于批处理。

在我看来, 存储过程就是有业务逻辑和流程的集合, 可以在存储过程中创建表,更新数据, 删除等等。

为什么要使用存储过程

通过把处理封装在容易使用的单元中,简化复杂的操作(正如前面例子所述)。

由于不要求反复建立一系列处理步骤,这保证了数据的完整性。如果所有开发人员和应用程序都使用同一(试验和测试)存储过程,则所使用的代码都是相同的。这一点的延伸就是防止错误。需要执行的步骤越多,出错的可能性就越大。防止错误保证了数据的一致性。

简化对变动的管理。如果表名、列名或业务逻辑(或别的内容)有变化,只需要更改存储过程的代码。使用它的人员甚至不需要知道这些变化。

一个简单的存储过程

(无参数。可以不指定参数。)

create procedure porcedureName ()

begin

select name from user;

end;

①也可以用Navicate直接创建存储过程:

②参数属性

注意事项:

在navicat管理工具中,新建查询。

存储过程用create procedure 创建, 业务逻辑和sql写在begin和end之间。mysql中可用call porcedureName ();来调用过程。

-- 调用过程

call porcedureName ();

该存储过程没有参数, 只是在调用的时候查询了用户表的用户名而已, 调用结果如下

name

admin

admin1

删除存储过程

DROP PROCEDURE IF EXISTS porcedureName; -- 没有括号()

使用参数的存储过程

(输出的参数)

create procedure procedureName(

out min decimal(8,2),

out avg decimal(8,2),

out max decimal(8,2)

)

BEGIN

select MIN(price) INTO min from order;

select AVG(price) into avg from order;

select MAX(price) into max from order;

END;

此过程接受三个参数, 分别用于获取订单表的最小、平均、最大价格。每个参数必须具有指定的类

型,这里使用十进制值(decimal(8,2)), 关键字OUT指出相应的参数用来从存储过程传出

一个值(返回给调用者)

MySQL支持IN(传递给存储过程)、OUT(从存储过程传出,如这里所用)和INOUT(对存储过程传入和传出)类型的参数。存储过程的代码位于BEGIN和END语句内,如前所见,它们是一系列SELECT语句,用来检索值,然后保存到相应的变量(通过指定INTO关键字)

为调用此修改过的存储过程,必须指定3个变量名,如下所示:(所有MySQL变量都必须以@开始。)

-- 由于过程指定三个参数, 故调用必须要参数匹配

call procedureName(@min, @avg, @max);

该调用并没有任何输出, 只是把调用的结果赋给了调用时传入的变量(@min, @avg, @max)。然后即可调用显示该变量的值。

(传递输出参数时,都要这样前面加一个@)

select @min, @avg, @max;

结果如下

@min @avg @max

42.00 601.00 2222.00

使用in参数, 输入一个用户id, 返回该用户所有订单的总价格。

create procedure getTotalById (

in userId int,

out total decimal(8,2)

)

BEGIN

select SUM(r.price) from order r

where r.u_id = userId

into total;

END;

调用存储过程

call getTotalById(1, @total);

select @total;

结果将返回该用户所有订单的合计价格。

复杂一点的过程, 根据用户id获取该用户的所有订单价格, 并动态的选择是否加税。代码设计如下

create procedure getTotalByUser2(

in userId int,

in falg boolean, -- 是否加税标记

out total decimal(8,2)

)

begin

DECLARE tmptotal DECIMAL(8,2);

DECLARE taxrate int DEFAULT 6;-- 默认的加税的利率

select SUM(r.price) from order r   -- 我的电脑运行这里会报错,后面发现是无法识别order表,改成这样就好了`order`

where r.u_id = userId

into tmptotal;

if falg then

select tmptotal + (tmptotal/1000*taxrate) into tmptotal;

end if;

select tmptotal into total;

END;

该过程传入三个参数, 用户id, 是否加税以及返回的总价格,在过程内部, 定义两个局部变量tmptotal和taxrate,把查询出来的结果赋给临时变量, 在判断是否加税。最后把局部变量的值赋给输出参数。

call getTotalByUser2(1, false, @total); -- 不加税   100

call getTotalByUser2(1, true, @total);  -- 加税    100.66

select @total;

参考自mysql必知必会, 转载请注明出处。

本文转自建波李 51CTO博客,原文链接:http://blog.51cto.com/jianboli/1884019,如需转载请自行联系原作者

mySql存储过程,简单实现实例相关推荐

  1. mysql存储过程实例实现查询_Mybatis应用mysql存储过程查询数据实例

    1.创建mysql存储过程,这是个复杂查询加上了判断,比较复杂 CREATE PROCEDURE searchAllList ( IN tradingAreaId VARCHAR (50), IN c ...

  2. mysql存储过程语法及实例

    存储过程如同一门程序设计语言,同样包含了数据类型.流程控制.输入和输出和它自己的函数库. --------------------基本语法-------------------- 一.创建存储过程 c ...

  3. mysql 存储过程简单使用_mysql存储过程的简单使用教程

    存储过程如同一门程序设计语言,同样包含了数据类型.流程控制.输入和输出和它自己的函数库. --------------------基本语法-------------------- 一.创建存储过程 c ...

  4. 软件测试mysql存储过程的用处实例_软件测试中实际应用:MySQL5存储过程编写

    软件测试中实际应用:MySQL5存储过程编写 MySql5.0以后均支持存储过程,最近有空,研究了一把这个. 格式: CREATE PROCEDURE 过程名 ([过程参数[,...]]) [特性 . ...

  5. mysql简单的存储过程实例_mysql存储过程简单实例

    MySql存储过程简单实例: /********************* 创建表 *****************************/ delimiter // DROP TABLE if ...

  6. MySql 存储过程实例(附完整注释)

    将下面的语句复制粘贴可以一次性执行完,我已经测试过,没有问题! MySql存储过程简单实例:                                                       ...

  7. mysql的存储过程正负数的变化_《转》mysql存储过程语法及范例

    <转>mysql存储过程语法及实例 存储过程如同一门程序设计语言,同样包含了数据类型.流程控制.输入和输出和它自己的函数库. --------------------基本语法------- ...

  8. mysql存储过程 cursor_MySql存储过程 CURSOR循环

    游标 游标(Cursor)是处理数据的一种方法,为了查看或者处理结果集中的数据,游标提供了在结果集中一次一行或者多行前进或向后浏览数据的能力. 使用步骤 声明一个游标: declare 游标名称 CU ...

  9. mysql存储过程 php_PHP调用MYSQL存储过程实例

    说一下 在PHP页面中调用MYSQL存储过程的方法 以下是几个例子 仅供参考 实例一:无参的存储过程 $conn = mysql_connect('localhost','root','root') ...

最新文章

  1. request.getServletPath()和request.getPathInfo()用法
  2. Page.OnPreInit 方法
  3. Linux安装FTP服务-----vsftpd
  4. Swift学习字符串、数组、字典
  5. Redis-3.2主从复制与集群搭建 推荐
  6. c++调用子进程捕获输出(windows,linux)
  7. 软件编程常用数据类型打印print
  8. python的while嵌套循环_Python中嵌套的WHILE循环
  9. 学习Bash shell编程资料推荐
  10. Windows杀死Tomcat进程
  11. 爬取网易严选某种衣服商品数据,实现可视化,结论有点吓人
  12. 设计师网页导航 php,设计师必须收藏的7个网址导航
  13. Linux系统上没有scp命令,Linux scp命令没反应
  14. Postgresql13.1增量排序BUG
  15. 计算机磁盘清理软件,清理磁盘空间的7种技巧,电脑装机、安装系统必备
  16. 宇宙最强IDE!微软正式宣布 Visual Studio 2019
  17. 计算机的软件教学设计七年级,计算机软件系统教学设计
  18. python文件输出exe文件反汇编_python 反编译exe文件为py文件的实例代码
  19. C语言:while与do while循环语句
  20. lm80认证_什么是LM-80测试什么产品需要做LM-80测试

热门文章

  1. android StringBuffer的使用
  2. error: invalid use of incomplete type 'XXXX' ;error: forward declaration of 'XXXX' 声明改为包含头文件
  3. Java并发编程—notify和notifyAll有什么区别?
  4. Spring整合Mybatis之注解方式,(注解整合Junit)
  5. 使用conda安装pydot及其遇到的问题解决方案
  6. setInterval(callback(),time)
  7. DB2快速入门的捷径pdf
  8. 国王的游戏(华东师范大学-信息学竞赛学教案)
  9. 组态王6.55连接MySql数据库(笔记)
  10. flash 编程技巧应用 原创