日期:2014-05-16 浏览次数:20791 次
来源: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
???
->
<