这篇文章主要介绍“MySQL5.0中的Function和Procedure实例用法”,在日常操作中,相信很多人在MySQL5.0中的Function和Procedure实例用法问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”MySQL5.0中的Function和Procedure实例用法”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
创新互联建站,为您提供网站建设公司、成都网站制作公司、网站营销推广、网站开发设计,对服务成都茶楼设计等多个行业拥有丰富的网站建设及推广经验。创新互联建站网站建设公司成立于2013年,提供专业网站制作报价服务,我们深知市场的竞争激烈,认真对待每位客户,为客户提供赏心悦目的作品。 与客户共同发展进步,是我们永远的责任!
创建函数(Function)
创建:
mysql> CREATE FUNCTION MyFunc (s CHAR(20)) RETURNS CHAR(50) RETURN CONCAT
('Hello',s,'.Lan',' !');
使用:
mysql> select MyFunc('Dennis');
删除:
drop function MyFunc;
创建存储过程(Procedure)
创建:
(由于存储过程是用";"结尾的,而";"在mysql默认的sql结尾.所以在这里要先改mysql的这个结束符)
mysql> delimiter |
mysql> CREATE PROCEDURE MyProc (OUT param1 INT) BEGIN SELECT COUNT(*) INTO
param1 FROM mysql.user; END;
-> |
官方文档:http://www.mysql.com/doc/en/CREATE_PROCEDURE.html
调用:
第一步:
mysql> CALL MyProc(@a)|
第二步:
mysql> select @a;
-> |
完整的例子:
mysql> CREATE PROCEDURE MyProc (OUT param1 INT) BEGIN SELECT COUNT(*) INTO
param
1 FROM mysql.user; END;
-> |
Query OK, 0 rows affected (0.00 sec)
mysql> call MyProc(@a)|
Query OK, 0 rows affected (0.03 sec)
mysql> select @a |
+------+
| @a |
+------+
| 4 |
+------+
1 row in set (0.00 sec)
删除:
mysql> drop procedure MyProc|
(注意,这里存储过程的名字是区分大小写的)
注: 如果你在和程序连接时出现:
Client does not support authentication protocol requested by server; consider upgrading
MySQL client
[@more@]
到此,关于“MySQL5.0中的Function和Procedure实例用法”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注创新互联网站,小编会继续努力为大家带来更多实用的文章!