[转载]MySQL5.0中的Function和Procedure

MySQL5.0中的Function和Procedure
MySQL5.0中的Function和Procedure

创建函数(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
请参考 http://www.mysql.com/doc/en/Old_client.html 这里提供了完整的解决方案.

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/374079/viewspace-132057/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/374079/viewspace-132057/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值