zoukankan      html  css  js  c++  java
  • mysql 程序编写实例

    DELIMITER $$

    drop trigger if exists `updata_depart_lead_name`;
    -- 新建触发器 --
    -- 功能:在更新部门的领导编号是,自动填写部门领导名字 --
    create trigger `updata_depart_lead_name` before update on `department`
    for each row BEGIN
    set @lead_name = '';

    if new.lead_id is null or new.lead_id = '' then
    set @lead_name = null;
    ELSE
    select name into @lead_name from staff where id = new.lead_id;
    end IF;

    set new.lead_name = @lead_name;
    END

    $$

    ————————————————————————————————————————————————————————————————————————————————

    delimiter $$

    drop trigger if exists `insert_depart_lead_name`;
    -- 新建触发器 --
    -- 功能:在新增部门时,自动填写部门领导的名字 --
    create trigger `insert_depart_lead_name` BEFORE insert on `department`
    for each row BEGIN
    set @lead_name = '';
    if new.lead_id is null or new.lead_id = '' THEN
    set @lead_name = null;
    ELSE
    select name into @lead_name from staff where id = new.lead_id;
    end if;
    set new.lead_name = @lead_name;
    end

    $$

    —————————————————————————————————————————————————————————————————————————————————————

    delimiter $$

    drop trigger if EXISTS `remove_depart_lead_on_delete_staff`;
    -- 在删除staff时,清空department中领导为该staff的领导信息 --
    create trigger `remove_depart_lead_on_delete_staff` after DELETE on `staff`
    for each row BEGIN
    update department set lead_id = null, lead_name = null where lead_id = old.id;
    end
    $$

    ————————————————————————————————————————————————————————————————————————————————————————

    delimiter $$

    drop trigger if exists `trigger_cursor`;

    create trigger `trigger_cursor` after insert on `staff`
    for each row BEGIN
    declare staff_id int ;
    DECLARE done int default false;
    DECLARE cur_test CURSOR FOR
    select id from staff ;
    declare CONTINUE HANDLER FOR not FOUND set done = true;
    open cur_test;
    read_loop:LOOP
    fetch cur_test into staff_id;
    if done then
    LEAVE read_loop;
    ELSE
    insert into message values(null, '1');
    end if;
    end loop;
    END
    $$

  • 相关阅读:
    数据库分库分表(sharding)系列(五) 一种支持自由规划无须数据迁移和修改路由代码的Sharding扩容方案
    数据库分库分表(sharding)系列(三) 关于使用框架还是自主开发以及sharding实现层面的考量
    docker的入门简介
    nginx方向代理详解及配置
    nginx配置文件详解
    nginx安装
    iptables防火墙
    服务器加载过程
    服务器
    操作系统
  • 原文地址:https://www.cnblogs.com/qufanblog/p/6950962.html
Copyright © 2011-2022 走看看