mysql存储过程怎么建 mysql存储过程怎么创建( 二 )


? while语句是存储过程或函数中表达循环执行的一种方式
? Return语句用在函数中 , 用来终结函数的执行并将指定值返回给调用者
? Cursor游标用来声明一个数据集
? 游标的声明必须在变量和条件声明之后,在handler声明之前
? Cursor close语句用来关闭之前打开的游标
? Cursor declare语句用来声明一个游标和指定游标对应的数据集合,通常数据集合是一个select语句
? Cursor fetch语句用来获取游标指定数据集的下一行数据并将各个字段值赋予后面的变量
? Open cursor语句用来打开一个之前已经声明好的游标
? Declare condition语句命名特定的错误条件,而该特定错误可以在declare…handler中指定处理方法
? 比如在MySQL中1051error code表示的是unknown table的错误,如果要对这
个错误做特殊处理,可以用三种方法:
? Declare handler语句用来声明一个handler来处理一个或多个特殊条件,当其中的某个条件满足时则触发其中的statement语句执行
? Statement可以是一个简单SQL语句,也可以是begin…end组成的多个语句
? Handler_action子句声明当执行完statement语句之后应该怎么办
Condition_value的值有以下几种:
? 当condition发生但没有声明handler时 , 则存储过程和函数依照如下规则处理
? create trigger语句用来创建一个触发器,触发器的作用是当表上有对应SQL语句发生时 , 则触发执行
? 触发器创建时需要指定对应的表名tbl_name
?Definer关键词用来指定trigger的安全环境
? Trigger_time指定触发器的执行时间 , BEFORE和AFTER指定触发器在表中的每行数据修改前或者后执行
? Trigger_event指定触发该触发器的具体事件
? INSERT当新的一行数据插入表中时触发 , 比如通过执行insert,load data,replace语句插入新数据
? UPDATE当表的一行数据被修改时触发 , 比如执行update语句时
? DELETE当表的一行数据被删除时触发,比如执行delete,replace语句时
【mysql存储过程怎么建 mysql存储过程怎么创建】? 当执行insert into … on duplicate key update语句时 , 当碰到重复行执行update时,则触发update下的触发器
? 从5.7.2版本开始,可以创建具有相同trigger_time和trigger_event的同一个表上的多个触发器 , 默认情况下按照创建的时间依次执行,通过指定FOLLOWS/PRECEDES改变执行顺序,即FOLLOWS时表示新创建的触发器后执行 , PRECEDES则表示新触发器先执行
? Trigger_body表示触发器触发之后要执行的一个或多个语句,在内部可以引用涉及表的字段,OLD.col_name表示行数据被修改或删除之前的字段数据 , NEW.col_name表示行数据被插入或修改之后的字段数据
? Drop trigger语句用来删除一个触发器
? If exists短语用来避免删除不存在的触发器时引发报错
?当你执行drop table时,表上的触发器也被drop掉了
如何通过用MySQL怎么创建存储过程?创建存储过程
CREATE PROCEDURE 存储过程名()
一个例子说明mysql存储过程怎么建:一个返回产品平均价格的存储过程如下代码mysql存储过程怎么建:
CREATE PROCEDURE productpricing()
BEGIN
SELECT Avg(prod_price) AS priceaverage
FROM products;
END;
//创建存储过程名为productpricing,如果存储过程需要接受参数,可以在()中列举出来 。即使没有参数后面仍然要跟() 。BEGIN和END语句用来限定存储过程体,过程体本身是个简单的SELECT语句
mysql怎么创建存储过程直接create procedure就可以啊
一般语法mysql存储过程怎么建:

推荐阅读