mysql之存储过程
call productpricing ( @ pricelow,
@ pricehigh,
@ priceaverage
);
CREATE PROCEDURE productpricing()
BEGIN
SELECT AVG(prod_price) AS priceaverage
FROM products;
END;
DELIMITER //
CREATE PROCEDURE productpricing()
BEGIN
SELECT AVG(prod_price) AS priceaverage
FROM products;
END //
DELIMITER ;
CALL productpricing();
结果是:
+--------------+
| priceaverage |
+--------------+
| 16.133571 |
+--------------+
DROP PROCEDURE productpricing;
DELIMITER //
CREATE PROCEDURE pricing(
OUT pl DECIMAL(8, 2),
OUT ph DECIMAL (8, 2),
OUT pa DECIMAL (8, 2),
)
BEGIN SELECT MIN (prod_price)
INTO pl
FROM productes;
SELECT MAX (prod_price)
INTO ph
FROM productes;
SELECT AVG (prod_price)
INTO pa
FROM productes; END // DELIMITER ;
CALL pricing (@pricelow, @pricehigh, @pricevarage );
SELECT @pricevarage
输出:
+--------+
| @pricevarage|
+--------+
| 55.00 |
+--------+
为了获得 3个值,可使用以下语句:
SELECT @pricelow, @pricehigh, @pricevarage ;
create procedure ordertotal (
in onumber int,
out ototal decimal (8,2)
)
begin
select sum(item_price * quantity)
from orderitems
where order_num = onumber
into ototal;
end //
call ordertotal(20005, @total);
SELECT @total;
输出:
+--------+
| @total |
+--------+
| 192.37|
+--------+
call ordertotal(20009, @total);
SELECT @total;
输出:
+--------+
| @total |
+--------+
| 38.47 |
+--------+
以后我们每次要通过订单号,来获得商品的总价都可以使用这个方式。是不是很有用啊。。
-- Name: ordertotal // 添加注释
-- Parameters: onumber = order number
-- taxable = 0 if not taxable, 1 if taxtable
-- ototal = order total variable CREATE PROCEDURE ordertotal (
IN onumber INT,
IN taxable BOOLEAN,
OUT ototal DECIMAL(8,2)
) COMMENT 'Obtain order total, optionally adding tax'
BEGIN
-- Declare variable for total
DECLARE total DECIMAL(8.2); // 声明变量
-- Declare tax percentage
DECLARE taxrate INT DEFAULT 6; -- Get the order total
SELECT SUM(item_price * quantity)
FROM orderitems
WHERE order_num = onumber
INTO total -- Is this taxable?
IF taxable THEN
-- Yes, so add taxrate to the total
SELECT total + (total / 100 * taxrate) INTO total;
END IF;
-- And finally, save to out variable
SELECT total INTO ototal;
END;
call ordertotal(20009, 0,@total);
SELECT @total;
输出:
+--------+
| @total |
+--------+
| 38.47 |
+--------+
第二条:
call ordertotal(20009, 1,@total);
SELECT @total;
输出:
+--------+
| @total |
+--------+
| 36.21 |
+--------+
show create procedure ordertotal;
SHOW PROCEDURE STATUS like 'ordertotal';
mysql之存储过程的更多相关文章
- MYSQL中存储过程的创建,调用及语法
		MySQL 存储过程是从 MySQL 5.0 开始增加的新功能.存储过程的优点有一箩筐.不过最主要的还是执行效率和SQL 代码封装.特别是 SQL 代码封装功能,如果没有存储过程,在外部程序访问数据库 ... 
- MYSQL分页存储过程及事务处理
		最近给客户做的一小系统是SQLSERVER的数据库,因为特殊原因要切换到MYSQL上去,切换数据库确实让人头疼的,SQLSERVER和MYSQL的存储过程还是有很大差别的,下面是我做切换时转换的MYS ... 
- MySQL的存储过程1
		来源:http://blog.sina.com.cn/s/blog_52d20fbf0100ofd5.html MySQL的存储过程 2. 关于MySQL的存储过程存储过程是数据库存储的一个重要的功能 ... 
- Mysql的存储过程(以Mysql为例进行讲解)
		我们常用的操作数据库语言SQL语句在执行的时候需要要先编译,然后执行,而存储过程(Stored Procedure)是一组为了完成特定功能的SQL语句集,经编译后存储 在数据库中,用户通过指定存 ... 
- mysql之——存储过程 + 游标 + 事务
		下面是自己曾经编写过的mysql数据库存储过程,留作存档,以后用到的时候拿来参考. 其中,涉及到了存储过程.游标(双层循环).事务. [说明]:代码中的注释只针对当时业务而言,无须理会. 代码如下: ... 
- MYSQL:基础—存储过程
		MYSQL:基础-存储过程 快速入门 理解: 迄今为止,我们学过的大多数SQL语句都是针对一个或多个表的单条语句.但是并不是所有的操作都是可以用一条语句来完成的,经常有一些操作是需要多条语句配合才能完 ... 
- MySQL笔记 存储过程 游标 触发器
		第二十三章 使用存储过程 MySQL5 中添加了存储过程的支持. 大多数SQL语句都是针对一个或多个表的单条语句.并非所有的操作都怎么简单.经常会有一个完整的操作需要多条才能完成 存储过程简单来说,就 ... 
- MySQL  列出存储过程
		MySQL 列出存储过程 接下来介绍如何列出MySQL数据库中的所有存储过程,并显示存储过程源代码的一些非常有用的语句. MySQL为提供了一些有用的语句,可以更有效地管理存储过程.这些语句包括列出 ... 
- [转]MYSQL 创建存储过程
		MySQL 存储过程是从 MySQL 5.0 开始增加的新功能.存储过程的优点有一箩筐.不过最主要的还是执行效率和SQL 代码封装.特别是 SQL 代码封装功能,如果没有存储过程,在外部程序访问数据库 ... 
随机推荐
- 在win 7 vs2013下 web 调试 出现“ iis Express Worker Process 已停止工作”错误
			在win 7 vs2013下 web 调试 出现“ iis Express Worker Process 已停止工作”错误: 如下图: 最终解决方案如下: 用管理员身份运行CMD,输入netsh ... 
- Mvc请求管道中的19个事件
			下面是请求管道中的19个事件. (1)BeginRequest: 开始处理请求 (2)AuthenticateRequest授权验证请求,获取用户授权信息 (3):PostAuthenticateRe ... 
- chrome表单自动填充去掉input黄色背景解决方案
			设置css代码如下: input:-webkit-autofill { -webkit-box-shadow: 0 0 0px 1000px white inset; } 参考文章:http://bl ... 
- JuQueen(线段树 lazy)
			JuQueen Time Limit: 5 Sec Memory Limit: 512 MB Description Input Output Sample Input 10 10 5 state ... 
- sql注入过滤的公共方法
			/// <summary> ///SQL注入过滤 /// </summary> /// <param name="InText">要过滤的字符串 ... 
- keytool的使用
			1. 创建数字证书 keytool -genkey -v -alias scent -dname "CN=John,OU=MNG,O=Corp,L=Hangzhou,ST=Zhejiang, ... 
- 不同系统下的回车\r和换行\n,及其历史
			我们平时按下键盘上的‘回车键’,就能实现回车换行[我们在屏幕上所看到的就是光标移到了下一行的开头位置!!ps:不讨论软件实现的特殊功能,如word里的回车智能缩进].因此对这个按键更准确说应该叫做‘回 ... 
- 【双标记线段树】bzoj1798维护序列seq
			一.题目 描述 老师交给小可可一个维护数列的任务,现在小可可希望你来帮他完成. 有长为N的数列,不妨设为a1,a2,-,aN .有如下三种操作形式: (1)把数列中的一段数全部乘一个值; (2)把数列 ... 
- python 注意事项
			常见错误 #4: 不理解Python的作用域 Python是基于 LEGB 来进行作用于解析的, LEGB 是 Local, Enclosing, Global, Built-in 的缩写.看起来“ ... 
- opengl视图变换 投影变换推导
			视图变换在opengl中,视图变换的输入是:(1)眼睛位置(或者说相机位置)eys:(2)眼睛朝向的中心center,(就是眼睛朝哪里看);(3)头的方向up.任何一点经过视图变换后都会转化到眼睛坐标 ... 
