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

来源:http://blog.csdn.net/ACMAIN_CHM/archive/2009/07/25/4380183.aspx

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>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值