网站开发人员主要干什么的,wordpress 正文宽度,网站建设功,百度贴吧官网存储过程存储过程简单来说#xff0c;就是为以后的使用而保存的一条或多条MySQL语句的集合。可将其视为批件#xff0c;虽然它们的作用不仅限于批处理。在我看来#xff0c; 存储过程就是有业务逻辑和流程的集合#xff0c; 可以在存储过程中创建表#xff0c;更新数据就是为以后的使用而保存的一条或多条MySQL语句的集合。可将其视为批件虽然它们的作用不仅限于批处理。在我看来 存储过程就是有业务逻辑和流程的集合 可以在存储过程中创建表更新数据 删除等等。为什么要使用存储过程通过把处理封装在容易使用的单元中简化复杂的操作(正如前面例子所述)。由于不要求反复建立一系列处理步骤这保证了数据的完整性。如果所有开发人员和应用程序都使用同一(试验和测试)存储过程则所使用的代码都是相同的。这一点的延伸就是防止错误。需要执行的步骤越多出错的可能性就越大。防止错误保证了数据的一致性。简化对变动的管理。如果表名、列名或业务逻辑(或别的内容)有变化只需要更改存储过程的代码。使用它的人员甚至不需要知道这些变化。一个简单的存储过程create procedure porcedureName ()beginselect name from user;end;存储过程用create procedure 创建 业务逻辑和sql写在begin和end之间。mysql中可用call porcedureName ();来调用过程。-- 调用过程call porcedureName ();该存储过程没有参数 只是在调用的时候查询了用户表的用户名而已 调用结果如下nameadminadmin1admin2admin3删除存储过程DROP PROCEDURE IF EXISTS porcedureName; -- 没有括号()使用参数的存储过程create procedure procedureName(out min decimal(8,2),out avg decimal(8,2),out max decimal(8,2))BEGINselect 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;结果如下minavgmax42.00601.002222.00使用in参数, 输入一个用户id 返回该用户所有订单的总价格。create procedure getTotalById (in userId int,out total decimal(8,2))BEGINselect SUM(r.price) from order rwhere r.u_id userIdinto total;END;调用存储过程call getTotalById(1, total);select total;结果将返回该用户所有订单的合计价格。复杂一点的过程 根据用户id获取该用户的所有订单价格 并动态的选择是否加税。代码设计如下create procedure getTotalByUser2(in userId int,in falg boolean, -- 是否加税标记out total decimal(8,2))beginDECLARE tmptotal DECIMAL(8,2);DECLARE taxrate int DEFAULT 6;-- 默认的加税的利率select SUM(r.price) from order rwhere r.u_id userIdinto tmptotal;if taxable thenselect tmptotal (tmptotal/1000*taxrate) into tmptotal;end if;select tmptotal into total;END;该过程传入三个参数 用户id 是否加税以及返回的总价格在过程内部 定义两个局部变量tmptotal和taxrate把查询出来的结果赋给临时变量 在判断是否加税。最后把局部变量的值赋给输出参数。call getTotalByUser2(1, false, total); -- 不加税call getTotalByUser2(1, true, total); -- 加税select total;参考自mysql必知必会 转载请注明出处。