MySQL5.6 触发器的使用(条件分支、变量的使用)
2014-07-07 20:11
495 查看
create trigger check_record_delete_trigger after DELETE on check_record FOR EACH ROW begin set @count = (select count(*) from check_record where INSTRUMENT_ID = old.INSTRUMENT_ID); if @count = 0 then set @Ins = 'drop Instrument'; delete from product_info where product_id = old.INSTRUMENT_ID and product_flag = 0; elseif @count > 0 THEN set @Ins = 'Keep it'; end if; set @count = (select count(*) from check_record where REAGENT_ID = old.REAGENT_ID); if @count = 0 then set @Rea = 'drop Reagent'; delete from product_info where product_id = old.REAGENT_ID and product_flag = 1; elseif @count > 0 THEN set @Rea = 'Keep it'; end if; end;
这段代码的意思是,删除主表 check_record中的一条记录时,也要相应地删除product_info表中相关联的记录,用instrument_id和reagent_id关联。
因为product_info表中的prouct_id在check_record中体现为instrument_id和reagent_id两个字段(product_info表中包括两种记录:instrument和reagent),
并且在check_record中会有多条记录有相同的instrument_id和reagent_id,所以每次删除时要进行判断,如果check_record中还有instrument_id或者reagent_id存在,那么
procut_info中就不能删,反之如果check_record中已经没有了特定值的instrument_id和reagent_id,那么product_info中的对应记录也就失去了存在的意义,所以要删除。
有几个注意点:
1. 关于if else分支在mysql中的使用,只能出现在存储过程、函数或者触发器中,如果在控制台中普通的查询语句中出现if else是会报语法错误的。
2. 有if, 就必须有end if,不然就报语法错误,这一点和java、JS等语言不一样,并且,end if后面必须加分号,不然报错。
3. 关于给变量赋值,必须以 set...开头,set不能省略,否则报语法错误。
4. 关于”old“,它指的是刚被删除的那条记录,也就是说,这条记录中的字段值还是可以拿出来用一下的。
相关文章推荐
- MySQL5.6 触发器的使用(条件分支、变量的使用)
- MySQL触发器中变量的使用
- MySQL 5.6 if与end if在触发器中的使用
- mysql:使用字符串变量作查询条件
- mysql存储过程中使用select count(*) into 变量名 from +表+ where条件的用法
- MySQL 5.6 if与end if在触发器中的使用
- Mysql 触发器的使用
- 避免使用条件分支
- where条件对mysql多列索引的使用
- mysql命令(客户端登陆与mysql -uxxx -pxxx的区别;环境变量的使用)
- MySql 中的 触发器使用
- mysql 储存过程、触发器的创建、删除及使用
- mysql变量使用总结
- 在java switch中使用String作为分支条件
- MYSQL存储过程中 使用变量 做表名
- mysql 存储过程中 使用变量做表明[学习记录]
- Mysql:命令选项、配置选项、(全局、会话)系统变量、状态变量:如何使用系统变量?
- MySQL存储过程和触发器使用释疑
- 在mysql 中使用变量
- MySQL触发器的使用