mysql怎么建立函数 mysql如何创建函数( 二 )


在 MySQL 中创建函数时出现这种错误的解决方法:
set global log_bin_trust_function_creators=TRUE;
? Iterate语句仅出现在loop,repeat,while循环语句中 , 其含义表示重新开始此循环
? Leave语句表明退出指定标签的流程控制语句块
? 通常会用在begin…end,以及loop,repeat,while的循环语句中
? Loop语句是存储过程或函数中表达循环执行的一种方式
? repeat语句是存储过程或函数中表达循环执行的一种方式
? 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语句时
? 当执行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创建一个函数DELIMITER $$
CREATE FUNCTION `ChkInsert`(in_pk int) returns int
begin
declare _count int;
declare _returnValue int;
set _count = 0;
select count(列1) into _count from mysql怎么建立函数你mysql怎么建立函数的表 where列1 = in_pk;

推荐阅读