在做项目时,需要用到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;