当前位置:首页 > 系统运维 > 正文内容

MySQL 存储过程的创建方案

a8116255316年前 (2010-05-19)系统运维11

以下的文章主要介绍的是MySQL 存储过程的实际操作解析,我们大家都知道一个MySQL 存储过程主要包括名字,参数列表,还有包括很多的SQL语句与SQL语句集。以下就是具体内容的描述,

创建MySQL 存储过程:

语法:

CREATE PROCEDURE p()  BEGIN 

/*此存储过程的正文*/

END  CREATE PROCEDURE productpricing()  BEGIN  SELECT Avg(pro_price) AS priceaverage  FROM products;  END;   

begin…end之间是存储过程的主体定义

MySQL的分界符是分号(;)

调用存储过程的 *** 是:

CALL加上过程名以及一个括号

例如调用上面定义的MySQL 存储过程

CALL productpricing();  

哪怕是不用传递参数,存储过程名字后面的括号“()”也是必须的

删除存储过程的 *** 是:

DROP PROCUDURE productpricing; 

创建带参数的存储过程:

CREATE PROCUDURE productpricing(  OUT p1 DECIMAL(8,2),  OUT ph DECIMAL(8,2),  OUT pa DECIMAL(8,2)  )  BEGIN  SELECT Min(prod_price) INTO pl FROM products;  SELECT Max(prod_price) INTO ph FROM products;   SELECT Avg(prod_price) INTO pa FROM products;  END;   

DECIMAL用于指定参数的数据类型

OUT用于表明此值是用于从存储过程里输出

MySQL支持 OUT, IN, INOUT

调用带参数的MySQL 存储过程:

CALL productpricing(@pricelow,  @pricehigh,  @priceaverage);  

所有的参数必须以@开头

要想获取@priceaverage的值,用以下语句

SELECT @priceaverage;

获取三个的值,用以下语句

SELECT @pricehigh, @pricelow, @priceaverage; 

另一个带IN和OUT参数的存储过程:

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; 

添加一个完整的例子:(这是一个自定义分页的MySQL 存储过程)

DELIMITER $$  DROP PROCEDURE IF EXIstS `dbcall`.`get_page`$$  CREATE DEFINER=`root`@`localhost` PROCEDURE `get_page`(  /**//*Table name*/  tableName varchar(100),  /**//*Fileds to display*/  fieldsNames varchar(100),  /**//*Page index*/  pageIndex int,  /**//*Page Size*/  pageSize int,   /**//*Field to sort*/  sortName varchar(500),  /**//*Condition*/  strWhere varchar(500)  )  BEGIN   DECLARE fieldlist varchar(200);   if fieldsNames=''||fieldsNames=null THEN  set fieldlist='*';  else  set fieldlist=fieldsNames;   end if;  if strWhere=''||strWhere=null then  if sortName=''||sortName=null then   set @strSQL=concat('SELECT ',fieldlist,' FROM ',tableName,' LIMIT ',(pageIndex-1)*pageSize,',',pageSize);  else  set @strSQL=concat('SELECT ',fieldlist,' FROM ',tableName,' ORDER BY ',sortName,' LIMIT ',(pageIndex-1)*pageSize,',',pageSize);   end if;  else  if sortName=''||sortName=null then  set @strSQL=concat('SELECT ',fieldlist,' FROM ',tableName,' WHERE ',strWhere,' LIMIT ',(pageIndex-1)*pageSize,',',pageSize);  else  set @strSQL=concat('SELECT ',fieldlist,' FROM ',tableName,' WHERE ',strWhere,' ORDER BY ',sortName,' LIMIT ',(pageIndex-1)*pageSize,',',pageSize);   end if;  end if;   PREPARE stmt1 FROM @strSQL;   EXECUTE stmt1;  DEALLOCATE PREPARE stmt1;  END$$  DELIMITER ;  

上面说了这么多内容,是关于对MySQL 存储过程的介绍,不知道各位对MySQL的认识是不是更上一层楼了,时时关注ITjs,学习最新Mysql技术。

扫描二维码推送至手机访问。

版权声明:本文由2345好导航站长资讯发布,如需转载请注明出处。

本文链接:http://www.2345hao.cn/blog/index.php/post/20423.html

分享给朋友:

“MySQL 存储过程的创建方案” 的相关文章

windows 7鼠标停顿怎么办?windows 7 usb鼠标停顿的原因以及解决

windows 7鼠标停顿怎么办?windows 7 usb鼠标停顿的原因以及解决

很多使用Windows 7系统的朋友都想小编反应,假如暂停使用电脑,鼠标会出现停顿现象,这是怎么回事呢 该怎么解决呢 下面就和小编一起去看下Windows 7 usb鼠标停顿的解决方法吧。 由于Windows 7系统中有一项USB选择性暂停造成的。这项设置主要为了节电,当他检测到用户没有对系统进行...

windows 7系统的电脑发出嘟嘟嘟的声音该怎么解决?

windows 7系统的电脑发出嘟嘟嘟的声音该怎么解决?

在某些电脑中,机器内部蜂鸣器与系统的声音输出方案是相关联的,这样一来会导致当系统输出声音时,即使电脑没有连接外部音响或耳机,也会通过内置蜂鸣器发出“嘟嘟哔哔”的声音。这个问题主要出现在Windows 7电脑中,假如你的电脑恰好遇到了这样的问题,可参考下面的方法来解决: 1、在桌面“计算机”图标上右...

各个都很实用:windows 7系统电脑日常小技巧

各个都很实用:windows 7系统电脑日常小技巧

在使用Windows 7的时候很多用户对于系统的很多功能并不是很了解,也正是因为这样的不了解导致很多用户在使用Win 之后并不能体验Windows 7的功能便携和强大功能,导致很多用户对于Windows 7的认识还是比较模糊,不过为了让更多的朋友了解Windows 7的特点和便携应用,今天就为大家汇...

Win 7系统中其他声音正常但酷狗音乐没声音怎么回事

Win 7系统中其他声音正常但酷狗音乐没声音怎么回事

故障现象: Windows 7酷狗软件无声音,系统声音正常。 原因分析: 1. 查看酷狗软件设置 2. 查看系统设置 解决方案: 1. Windows 7操作方法 如图:查看是否处于禁音状态   Windows 7系统声音正常酷狗音乐无声音 2. 查看设置音频输出是否...

windows 7系统重装后卡在正在启动Windows开机界面怎么办

windows 7系统重装后卡在正在启动Windows开机界面怎么办

重装系统是我们面对许多电脑问题时的终极方法,不过重装系统也不意味着就能将全部的问题都修复。一些用户在重装系统后开机时,电脑卡在“正在启动Windows”开机界面上了,这要怎么解决呢? Windows 7系统重装后卡在开机界面的解决方法: 一、首先可以看看该故障出现的原因是否是因为启动了acp...

windows 7/8/xp系统关闭自动播放功能禁止音频媒体自动播放

windows 7/8/xp系统关闭自动播放功能禁止音频媒体自动播放

Windows 7/8系统: 控制面板——自动播放——取消掉为所有媒体和设备设置自动播放 winXP系统: 开始—运行—gpedit.msc—计算机配置—管理模板—系统—关闭自动播放—已启用—所有驱动器—确定  关闭自动运行功能说明: 一旦您将媒体插入驱动器...