MySQL触发器

/ 0评 / 0

⒈是什么?

  触发器就是某个表发生一个事件(增删改操作),然后自动的执行预先编译好的SQL语句,执行相关操作。触发器事件跟触发器中的SQL语句是原子性的(要么同时执行,要么同时不执行),这样保证了数据的完整性。

⒉创建触发器

  1.语法

drop trigger if exists databaseName.tri_Name; 
create trigger tri_Name  -- tri_Name代表触发器名称
tirgger_time trigger_event on tableName  -- tirgger_time为触发时机,可选值有after/before,trigger_event为触发事件,可选值有insert/update/delete
for each row   -- 这句话在mysql是固定的,表示任何一条记录上的操作满足触发事件都会触发该触发器。
begin 
    sql语句; 
end

  2示例

    ①insert类型触发器

drop trigger if exists study.tgr_users_insert; 
create trigger tgr_users_insert
before insert on users
for each row
begin
    set new.username='fanqi';    -- NEW用来表示将要(before)或已经(after)插入的新数据。
end;

②delete类型触发器

drop trigger if exists study.tgr_users_delete; 
create trigger tgr_users_delete
before delete on users
for each row
begin
    declare oldusername varchar(20) default 'fan';
    set oldusername = old.username;    -- old用来表示将要或已经被删除的原数据。
end;

③update类型触发器

使用实例

drop trigger if exists databaseName.tri_Name; 
create trigger tri_Name  -- tri_Name代表触发器名称
tirgger_time trigger_event on tableName  -- tirgger_time为触发时机,可选值有after/before,trigger_event为触发事件,可选值有insert/update/delete
for each row   -- 这句话在mysql是固定的,表示任何一条记录上的操作满足触发事件都会触发该触发器。
begin 
    sql语句; 
end
CREATE DEFINER=`root`@`localhost` trigger tri_update_insert_dept                             
after insert on sys_dept                                 
for each row                                                      
begin 
INSERT INTO `node-2`.`sys_dept`
( `id`, `name`, `parent_id`, `order_num`, `create_by`, `create_time`, `last_update_by`, `last_update_time`, `del_flag`, `com_level`, `dept_code`, `type` )
SELECT
`id`,
`name`,
`parent_id`,
`order_num`,
`create_by`,
`create_time`,
`last_update_by`,
`last_update_time`,
`del_flag`,
`com_level`,
`dept_code`,
`type`
FROM
    sys_dept
    where `id` = new.`id`;
end;
drop trigger if exists `node-1`.`tri_update_insert_dept`; 
create trigger tri_update_insert_dept                             
after insert on sys_dept                                 
for each row                                                      
begin 
INSERT INTO `node-2`.`sys_dept`
( `id`, `name`, `parent_id`, `order_num`, `create_by`, `create_time`, `last_update_by`, `last_update_time`, `del_flag`, `com_level`, `dept_code`, `type` )
SELECT
`id`,
`name`,
`parent_id`,
`order_num`,
`create_by`,
`create_time`,
`last_update_by`,
`last_update_time`,
`del_flag`,
`com_level`,
`dept_code`,
`type`
FROM
    sys_dept
    where `id` = new.`id`;
end

发表评论

电子邮件地址不会被公开。 必填项已用*标注