以下的文章主要介绍的是MySQL存储过程中的语法学习,主要内容包括名字,参数列表,与很多SQL语句的SQL语句集。以下就是具体方案的描述,希望会给你带来一些帮助在此学习方面。
10年积累的成都网站设计、成都网站制作经验,可以快速应对客户对网站的新想法和需求。提供各种问题对应的解决方案。让选择我们的客户得到更好、更有力的网络服务。我虽然不认识你,你也不认识我。但先网站制作后付款的网站建设流程,更有招远免费网站建设让你可以放心的选择与我们合作。
一个存储过程包括名字,参数列表,以及可以包括很多SQL语句的SQL语句集。
创建存储过程:
语法:
- CREATE PROCEDURE p()
- BEGIN
此存储过程的正文
- END
- CREATE PROCEDURE productpricing()
- BEGIN
- SELECT Avg(pro_price) AS priceaverage
- FROM products;
- END;
begin…end之间是存储过程的主体定义
MySQL的分界符是分号(;)
调用存储过程的方法是:
CALL加上过程名以及一个括号
例如调用上面定义的存储过程
- 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
调用带参数的存储过程:
- 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;
添加一个完整的例子:(这是一个自定义分页的存储过程)
- 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存储过程中的语法学习
标题链接:http://www.shufengxianlan.com/qtweb/news37/143387.html
网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联