您的位置:首页 > 数据库 > MySQL

MySql存储过程

2010-05-14 11:03 267 查看
在做项目时,需要用到Mysql的存储过程,总结如下:
mysql> delimiter //
mysql> CREATE PROCEDURE simpleproc (OUT param1 INT)
-> BEGIN
-> SELECT COUNT(*) INTO param1 FROM t;
-> END
-> //
Query OK, 0 rows affected (0.00 sec)

还是挺简单的,那么这个存储过程如何调用呢?

mysql> delimiter ;
MySql中delimiter的作用是什么?
这个命令与存储过程没什么关系吧。
其实就是告诉mysql解释器,该段命令是否已经结束了,mysql是否可以执行了。
默认情况下,delimiter是分号;。在命令行客户端中,如果有一行命令以分号结束,
那么回车后,mysql将会执行该命令。如输入下面的语句
mysql> select * from test_table;
然后回车,那么MySQL将立即执行该语句。

但有时候,不希望MySQL这么做。在为可能输入较多的语句,且语句中包含有分号。

默认情况下,不可能等到用户把这些语句全部输入完之后,再执行整段语句。
因为mysql一遇到分号,它就要自动执行。
这种情况下,就需要事先把delimiter换成其它符号,如//或$$。

等存储过程执行完之后,再转换回;就可以了

mysql> CALL simpleproc(@a);
Query OK, 0 rows affected (0.01 sec)

mysql> SELECT @a;
+------+
| @a |
+------+
| 317 |
+------+
1 row in set (0.00 sec)

mysql> select count(*) from ps_consume_record_00_00;
+----------+
| count(*) |
+----------+
| 317 |
+----------+
1 row in set (0.00 sec)
还是很简单的。呵呵。以下是我测试往个人版插入测试数据的一个存储过程,很简单,供参考。

drop PROCEDURE BatchInsert;
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息