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;