zoukankan      html  css  js  c++  java
  • 10触发器

    九、触发器
    CREATE DATABASE d;
    USE d;


    --创建d1,d2,d3,d4四个空表,装触发时的数据
    --表1
    CREATE TABLE d1
    (
    id TINYINT UNSIGNED NOT NULL,
    score INT UNSIGNED NOT NULL
    )ENGINE=MYISAM AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;

    --表2
    CREATE TABLE d2
    (
    id TINYINT UNSIGNED NOT NULL,
    score INT UNSIGNED NOT NULL
    )ENGINE=MYISAM AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;

    --表3
    CREATE TABLE d3
    (
    id TINYINT UNSIGNED NOT NULL,
    score INT UNSIGNED NOT NULL
    )ENGINE=MYISAM AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;

    --表4
    CREATE TABLE d4
    (
    id TINYINT UNSIGNED NOT NULL,
    score INT UNSIGNED NOT NULL
    )ENGINE=MYISAM AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;

    --创建触发器
    格式:create trigger trigger_name trigger_time(before/after) trigger_event(insert/update/delete)
    on tablename(要进行操作的表) for each row(此句存在,才有new和old,如下)

    insert update delete

    old null old.data old.data

    new nwe.data new.data null


    --创建插入触发器
    DELIMITER //
    CREATE TRIGGER t BEFORE INSERT ON d1 FOR EACH ROW
    BEGIN
    INSERT INTO d2 VALUE(new.id,new.score); --向d1插入数据时,并将新数据插入到d2
    END//
    DELIMITER ;

    --创建修改触发器
    DELIMITER //
    CREATE TRIGGER t2 BEFORE UPDATE ON d2 FOR EACH ROW
    BEGIN
    INSERT INTO d3 VALUE(old.id,old.score); --修改d2数据时,将原有的数据插入到d3
    INSERT INTO d4 VALUE(new.id,new.score); --将新数据插入到d4
    END//
    DELIMITER ;

    ----创建删除触发器
    DELIMITER //
    CREATE TRIGGER t3 BEFORE DELETE ON d3 FOR EACH ROW
    BEGIN
    INSERT INTO d1 VALUE(old.id,old.score); --删除d3数据时,将原有的数据插入到d1
    END//
    DELIMITER ;

    --查看各表数据
    SELECT * FROM d1;
    SELECT * FROM d2;
    SELECT * FROM d3;
    SELECT * FROM d4;

    --向d1插入数据
    INSERT INTO d1 VALUES(1,60),(2,70),(3,80),(4,90);


    --修改d2的数据
    UPDATE d2 SET id=5,score=20 WHERE id=1;
    UPDATE d2 SET id=6,score=30 WHERE id=2;
    UPDATE d2 SET id=7,score=40 WHERE id=3;
    UPDATE d2 SET id=8,score=50 WHERE id=4;

    --删除d3的某些数据
    DELETE FROM d3 WHERE id=1;

    --删除触发器
    DROP TRIGGER t2;

  • 相关阅读:
    10gen发布MongoDB增量备份服务
    JSON.NET 5中的架构变更
    Snowbox 2.0 发布,POP3 邮件服务器
    资源监控工具 glances
    Druid 0.2.18 发布,阿里巴巴数据库连接池
    Groovy 更新到 2.0.8 and 2.1.3
    Apache Libcloud 0.12.4 发布,统一云计算接口
    Go1.1性能测试报告(和C差距在10%以内)
    Apache Camel 2.11.0 发布,规则引擎
    2010年01月01日0时0分 总结我的2009
  • 原文地址:https://www.cnblogs.com/gd-luojialin/p/8506769.html
Copyright © 2011-2022 走看看