MySQL 中如何在触发器里中断记录的插入或更新?

原创 2009年07月25日 20:32:00

MySQL 不象其它有些数据库可以在触发器中抛出异常来中断当然触发器的执行以阻止相应的SQL语句的执行。在MySQL的目录版本中还无法直接抛出异常。这样我们如何实现呢?

 

下面是一种实现的方法。思路就是想办法在触发器中利用一个出错的语句来中断代码的执行。

 

mysql> create table t_control(id int primary key);
Query OK,
0 rows affected (0.11 sec)

mysql
> insert into t_control values (1);
Query OK,
1 row affected (0.05 sec)

mysql
> create table t_bluerosehero(id int primary key,col int);
Query OK,
0 rows affected (0.11 sec)

mysql
> delimiter //
mysql
> create trigger tr_t_bluerosehero_bi before insert on t_bluerosehero
   
-> for each row
   
-> begin
   
->  if new.col>30 then
   
->          insert into t_control values (1);
   
->  end if;
   
-> end;
   
-> //
Query OK,
0 rows affected (0.08 sec)

mysql
> delimiter ;
mysql
>
mysql
> insert into t_bluerosehero values (1,20);
Query OK,
1 row affected (0.25 sec)

mysql
> insert into t_bluerosehero values (2,40);
ERROR
1062 (23000): Duplicate entry '1' for key 'PRIMARY'
mysql
>
mysql
> select * from t_bluerosehero;
+----+------+
| id | col  |
+----+------+
|  1 |   20 |
+----+------+
1 row in set (0.00 sec)

mysql
>

或者

 

mysql> delimiter //
mysql
> create trigger tr_t_bluerosehero_bi before insert on t_bluerosehero
   
-> for each row
   
-> begin
   
->  declare i int;
   
->  if new.col>30 then
   
->          insert into xxxx values (1);
   
->  end if;
   
-> end;
   
-> //
Query OK,
0 rows affected (0.06 sec)

mysql
> delimiter ;
mysql
> delete from t_bluerosehero;
Query OK,
3 rows affected (0.05 sec)

mysql
> insert into t_bluerosehero values (1,20);
Query OK,
1 row affected (0.06 sec)

mysql
> insert into t_bluerosehero values (2,40);
ERROR
1146 (42S02): Table 'csdn.xxxx' doesn't exist
mysql>

mysql 触发器 trigger 中断操作 抛出异常

通常情况下会遇到如下需求,当insert的时候,如果已经有记录,则中断操作,抛出相应错误。 mysql命令行创建trigger的时候要注意一下分号的使用,因为mysql解析器遇到分号会执行,所以我们...
  • leocnx
  • leocnx
  • 2016年11月09日 16:23
  • 1641

【转】mysql触发器的实战经验(触发器执行失败,sql会回滚吗)

1   引言 Mysql的触发器和存储过程一样,都是嵌入到mysql的一段程序。触发器是mysql5新增的功能,目前线上凤巢系统、北斗系统以及哥伦布系统使用的数据库均是mysql5.0.45版本...

MySQL触发器与定时器的介绍和错误处理

MySQL触发器与定时器的介绍和错误处理方法最近在做一个东南亚的海外项目,整个项目的技术架构是由我负责,由于项目比较庞大,涉及三种语言,数据关系比较复杂,用的触发器、定时器比较多。借这个新型大项目,也...

mysql——我自己写的两张表(插入、删除、更新)同时进行的(触发器)实例

数据库如下: create database mytest; use mytest; DROP TABLE IF EXISTS `user1`; CREATE TABLE `user1` ( ...

Navicat for MySQL触发器更新和插入操作

一、触发器概念        触发器(trigger):监视某种情况,并触发某种操作,它是提供给程序员和数据分析员来保证数据完整性的一种方法,它是与表事件相关的特殊的存储过程,它的执行不是由程序调用,...

Navicat for MySQL触发器更新和插入操作

一、触发器概念        触发器(trigger):监视某种情况,并触发某种操作,它是提供给程序员和数据分析员来保证数据完整性的一种方法,它是与表事件相关的特殊的存储过程,它的执行不是由程序调用...

[数据库] Navicat for MySQL触发器更新和插入操作

一、触发器概念        触发器(trigger):监视某种情况,并触发某种操作,它是提供给程序员和数据分析员来保证数据完整性的一种方法,它是与表事件相关的特殊的存储过程,它的执行不是由程序调用,...

Navicat for MySQL触发器更新和插入操作

[引自本文 ](http://blog.csdn.net/eastmount/article/details/52344036)一、触发器概念        触发器(trigger):监视某种情况,并...

mysql 防止插入重复数据sql和触发器

这里主要使用了mysql中的虚拟表dual。 有时候我们希望在插入一行新数据前,直接在sql中判断这个数据段的值是不是有重复,比如说插入一个新栏目,判断这个栏目名称是否存在。 表blog_note...
  • sujudz
  • sujudz
  • 2012年11月03日 07:15
  • 7668

mysql 触发器 监听这个表插入时增加数据 在某字段变动时进行触发

mysql 触发器 监听这个表插入时增加数据 在某字段变动时进行触发
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:MySQL 中如何在触发器里中断记录的插入或更新?
举报原因:
原因补充:

(最多只允许输入30个字)