天天看点

MySql存储过程

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

还是很简单的。呵呵。以下是我测试往个人版插入测试数据的一个存储过程,很简单,供参考。

drop PROCEDURE BatchInsert;