关闭

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

标签: mysql存储数据库
404人阅读 评论(0) 收藏 举报
分类:

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

在触发器中,可以实现,在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('地址','广东省');








0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:21707次
    • 积分:527
    • 等级:
    • 排名:千里之外
    • 原创:27篇
    • 转载:11篇
    • 译文:1篇
    • 评论:5条
    最新评论