触发器及存储过程 同时增删模糊匹配字段

最近想写一个存储过程,过程为边插入边删除,其实本来可以利用触发器完成的,但是发现触发器有缺陷,于是改为存储过程。

在触发器中,可以实现,在A表中插入,在B表中同时插入,或者同时删除。也可以是,在A表中插入,在B表中删除。此时必须指定,插入和删除的字段的精确性,并且A、B表中必须拥有同样的唯一字段,比如id。

delimiter//
create trigger in_de
#注意无论是insert或是delete后面都是接on
after insert on test2 for each ROW
begin
delete from test1 where id = new.id
end //

 
 

我的目标是实现insert和delete同时增删模糊匹配字段,这种方式看来也是可以实现,但是需要自己手动新增一列id,同时写上insert 语句。那么,存储过程能否实现呢。

delimiter//
create procedure in_de(in column_name varchar(255),in a varchar(255))
begin
insert into test2 select * from test1 where column_name like '%a%';
delete from test2 where column_name like '%a%';
end //

利用普通存储过程可以发现,当我选择利用模糊匹配中的where column_name like '%a%‘ 来进行插删时,发现列名无法自己指定,那么就意味着like模糊匹配失去意义。所以必须寻找新的出路。在此本文采用procedure+prepare来实现。

<pre name="code" class="sql">DROP PROCEDURE IF EXISTS insert_delete;
DELIMITER //
CREATE PROCEDURE insert_delete(IN a VARCHAR(255),IN b VARCHAR(255))
BEGIN
#应用格式set + prepare from + execute(注意空格)
SET @sql1=CONCAT('insert into errordata select * from test2 where ',a,' like \'%',b,'%\'');
PREPARE s1 FROM @sql1;
EXECUTE s1;
SET @sql2=CONCAT('delete from test1 where ',a,' like \'%',b,'%\'');
PREPARE s2 FROM @sql2;
EXECUTE s2;
END//
DELIMITER ;
call insert_delete('地址','广东省');


 

 
 


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值