触发器学习之入门(增、删、改、增删改)
admin
2023-04-15 00:41:36
0


注:本文主要介绍使用触发器自动同步增、删、改的简单语句学习。

       如果在查阅中发现错误或不当的地方欢迎留言指出,大家相互学习。谢谢!


创建测试需要的表并插入数据,为了方便学习理解,这里列名都用的中文。

create table a(序号 VARCHAR2(10) primary key not null,姓名 VARCHAR2(20),岁数 number(3),地址 VARCHAR2(40));

create table b(序号 VARCHAR2(10) primary key not null,姓名 VARCHAR2(20),岁数 number(3),地址 VARCHAR2(40));

insert into a values (1,'张三',18,'中国');

insert into b values (1,'张三',18,'中国');

commit;


触发器自动同步INSERT

创建触发器:当A表中插入数据时自动同步插入到B表

create trigger inserts

after insert on a --表a中插入数据之后触发

for each row --行级别触发

begin --触发的操作如下

insert into b (序号,姓名,岁数,地址)

values(:new.序号,:new.姓名,:new.岁数,:new.地址);

end;

插入测试数据到A表

insert into a (序号,姓名,岁数,地址) values ('2','湛康颖','23','湖北');

commit;

查询验证可以看到A、B两表中数据已经得到同步。

select * from   a;

select * from   b;

触发器学习之入门(增、删、改、增删改)

触发器学习之入门(增、删、改、增删改)


触发器自动同步DELETE

创建触发器:当A表中删除数据时自动同步删除B表中数据

create trigger deletes

after delete on a --表a中删除数据之后触发

for each row --行级别触发

begin --触发的操作如下

delete from b where 序号=:old.序号;

end;

删除A表中序号为2的数据

delete a where 序号='2';

commit;

查询验证可以看到A、B两表中数据已经得到同步。

select * from a;

select * from b;

触发器学习之入门(增、删、改、增删改)

触发器学习之入门(增、删、改、增删改)


触发器自动同步UPDATE

创建触发器:当A表中更新数据时自动同步更新到B表

create or replace trigger updates

before update on a --表a中更新数据之后触发

for each row --行级别触发

begin --触发的操作如下

update b set 序号=:new.序号,姓名=:new.姓名,岁数=:new.岁数,地址=:new.地址

where 序号=:old.序号;

end;

更新A表中序号为1的记录,将张三改为李四

update a set 姓名='李四' where 序号='1';

commit;

查询验证可以看到A、B两表中数据已经得到同步。

select * from a;

select * from b;

触发器学习之入门(增、删、改、增删改)

触发器学习之入门(增、删、改、增删改)

测试完成后将触发器drop不然会影响下面操作。

drop trigger inserts;

drop trigger deletes;

drop trigger updates;


触发器自动同步INSERT、DELETE、UPDATE

创建触发器:当A表中有数据增删改时自动将操作同步到B表

create or replace trigger dmls

 after update or insert or delete on a --表a中增、删、改数据之后触发

 for each row --行级别触发

 begin --触发的操作如下

     if inserting then --如果是插入时运行下列插入语句,否则运行下一个判断

       insert into b (序号,姓名,岁数,地址)

       values(:new.序号,:new.姓名,:new.岁数,:new.地址);

     elsif deleting then --如果是删除时运行下列删除语句,否则运行下一个判断

       delete from b where 序号=:old.序号;

     else --运行下列更新语句

      update b set 序号=:new.序号,姓名=:new.姓名,岁数=:new.岁数,地址=:new.地址

      where 序号=:old.序号;

     end if;

    end;

对A表进行增删改操作进行测试

insert into a (序号,姓名,岁数,地址) values   ('3','奥巴马','58','美国');

delete a where 序号='1';

update a set 序号='1' where 序号='3';

commit;

查询验证可以看到A、B两表中数据已经得到同步。

select * from a;

select * from b;

触发器学习之入门(增、删、改、增删改)

触发器学习之入门(增、删、改、增删改)

相关内容

热门资讯

【第一消息】“福麻圈到底是不是... 您好:福麻圈这款游戏可以开挂,确实是有挂的,需要了解加客服微信【9784099】很多玩家在这款游戏中...
今日重大消息“悠悠众娱怎么开挂... 您好:悠悠众娱这款游戏可以开挂,确实是有挂的,需要了解加客服微信【9784099】很多玩家在这款游戏...
玩家攻略科普“四方棋牌可以开挂... 您好:四方棋牌这款游戏可以开挂,确实是有挂的,需要了解加客服微信【9752949】很多玩家在这款游戏...
玩家最新攻略“科乐吉林麻将真的... 家人们!今天小编来为大家解答科乐吉林麻将透视挂怎么安装这个问题咨询软件客服徽9752949的挂在哪里...
玩家攻略科普“杭麻圈辅助器?”... 网上科普关于“杭麻圈有没有挂”话题很是火热,小编也是针对杭麻圈作*弊开挂的方法以及开挂对应的知识点,...
终于了解“游游棋牌辅助器?”(... 终于了解“游游棋牌辅助器?”(透视曝光猫腻)您好,游游棋牌这个游戏其实有挂的,确实是有挂的,需要了解...
玩家最新攻略“星悦麻将辅助器?... 您好:星悦麻将这款游戏可以开挂,确实是有挂的,需要了解加客服微信【9784099】很多玩家在这款游戏...
【第一财经】“牵手跑胡子辅助器... 有 亲,根据资深记者爆料牵手跑胡子是可以开挂的,确实有挂(咨询软件无需打...
【今日要闻】“邳州麻将到底有挂... 【今日要闻】“邳州麻将到底有挂吗?”(外卦神器下载)您好,邳州麻将这个游戏其实有挂的,确实是有挂的,...
今日重大通报“阿道夫游戏到底是... 有 亲,根据资深记者爆料阿道夫游戏是可以开挂的,确实有挂(咨询软件无需打...