MySQL5.0存储过程教程

2019-01-03 14:50:08王振洲

  (1) Example with two DECLARE statements
  两个DECLARE语句的例子 

CREATE PROCEDURE p8 ()
BEGIN
DECLARE a INT;
DECLARE b INT;
SET a = 5;
SET b = 5;
INSERT INTO t VALUES (a);
SELECT s1 * a FROM t WHERE s1 >= b;
END; // /* I won't CALL this */
  在过程中定义的变量并不是真正的定义,你只是在BEGIN/END块内定义了而已(译注:也就是形参)。
Error Handling 异常处理
  好了,我们现在要讲的是异常处理
1. Sample Problem: Log Of Failures 问题样例:故障记录
  当INSERT失败时,我希望能将其记录在日志文件中我们用来展示出错处理的问题样例是很
普通的。我希望得到错误的记录。当INSERT失败时,我想在另一个文件中记下这些错误的
信息,例如出错时间,出错原因等。我对插入特别感兴趣的原因是它将违反外键关联的约束
2. Sample Problem: Log Of Failures (2)
mysql> CREATE TABLE t2
s1 INT, PRIMARY KEY (s1))
engine=innodb;//
mysql> CREATE TABLE t3 (s1 INT, KEY (s1),
FOREIGN KEY (s1) REFERENCES t2 (s1))
engine=innodb;//
mysql> INSERT INTO t3 VALUES (5);//
...
ERROR 1216 (23000): Cannot add or update a child row: a foreign key
constraint fails(这里显示的是系统的出错信息)
  我开始要创建一个主键表,以及一个外键表。我们使用的是InnoDB,因此外键关联检查是打
开的。然后当我向外键表中插入非主键表中的值时,动作将会失败。当然这种条件下可以很
快找到错误号1216。
3. Sample Problem: Log Of Failures

CREATE TABLE error_log (error_message
CHAR(80))//
  下一步就是建立一个在做插入动作出错时存储错误的表。

您可能感兴趣的文章:

MySQL存储过程例子(包含事务,输出参数,嵌套调用)mysql 存储过程中变量的定义与赋值操作MySQL 有输入输出参数的存储过程实例mysql 动态执行存储过程语句mysql 教程 存储过程mysql 存储过程的问题MySQL 存储过程和"Cursor"的使用方法MySQL5创建存储过程的示例MySQL与存储过程的相关资料php调用mysql存储过程MySQL 存储过程的基本用法介绍