1. <var id="fe6gj"></var>

    <rp id="fe6gj"><nav id="fe6gj"></nav></rp>

    <noframes id="fe6gj"><cite id="fe6gj"></cite>

    <ins id="fe6gj"><button id="fe6gj"><p id="fe6gj"></p></button></ins>
    1. <tt id="fe6gj"><i id="fe6gj"><sub id="fe6gj"></sub></i></tt>
        始創于2000年 股票代碼:831685
        咨詢熱線:0371-60135900 注冊有禮 登錄
        • 掛牌上市企業
        • 60秒人工響應
        • 99.99%連通率
        • 7*24h人工
        • 故障100倍補償
        您的位置: 網站首頁 > 幫助中心>文章內容

        MySQL 觸發器簡單實例

        發布時間:  2012/8/13 16:19:43

        1、語法:
        CREATE TRIGGER <觸發器名稱> --觸發器必須有名字,最多64個字符,可能后面會附有分隔符.它和MySQL中其他對象的命名方式基本相象.
        { BEFORE | AFTER } --觸發器有執行的時間設置:可以設置為事件發生前或后。
        { INSERT | UPDATE | DELETE } --同樣也能設定觸發的事件:它們可以在執行insert、update或delete的過程中觸發。
        -
         

        ON <表名稱> --觸發器是屬于某一個表的:當在這個表上執行插入、 更新或刪除操作的時候就導致觸發器的激活. 我們不能給同一張表的同一個事件安排兩個觸發器。
        FOR EACH ROW --觸發器的執行間隔:FOR EACH ROW子句通知觸發器 每隔一行執行一次動作,而不是對整個表執行一次。
        <觸發器SQL語句> --觸發器包含所要觸發的SQL語句:這里的語句可以是任何合法的語句, 包括復合語句,但是這里的語句受的限制和函數的一樣。

        --你必須擁有相當大的權限才能創建觸發器(CREATE TRIGGER),如果你已經是Root用戶,那么就足夠了。這跟SQL的標準有所不同。


        2、簡單實例:
        example1:
        --創建表tab1
        DROP TABLE IF EXISTS tab1;
        CREATE TABLE tab1(
            tab1_id varchar(11)
        );

        --創建表tab2
        DROP TABLE IF EXISTS tab2;
        CREATE TABLE tab2(
            tab2_id varchar(11)
        );

        --創建觸發器:t_afterinsert_on_tab1
        --作用:增加tab1表記錄后自動將記錄增加到tab2表中
        DROP TRIGGER IF EXISTS t_afterinsert_on_tab1;
        CREATE TRIGGER t_afterinsert_on_tab1
        AFTER INSERT ON tab1
        FOR EACH ROW
        BEGIN
             insert into tab2(tab2_id) values(new.tab1_id);
        END;

        --測試一下
        INSERT INTO tab1(tab1_id) values('0001');

        --看看結果
        SELECT * FROM tab1;
        SELECT * FROM tab2;


        example2:
        --創建觸發器:t_afterdelete_on_tab1
        --作用:刪除tab1表記錄后自動將tab2表中對應的記錄刪去
        DROP TRIGGER IF EXISTS t_afterdelete_on_tab1;
        CREATE TRIGGER t_afterdelete_on_tab1
        AFTER DELETE ON tab1
        FOR EACH ROW
        BEGIN
              delete from tab2 where tab2_id=old.tab1_id;
        END;

        --測試一下
        DELETE FROM tab1 WHERE tab1_id='0001';
        --看看結果
        SELECT * FROM tab1;
        SELECT * FROM tab2;


        本文出自:億恩科技【www.endtimedelusion.com】

        服務器租用/服務器托管中國五強!虛擬主機域名注冊頂級提供商!15年品質保障!--億恩科技[ENKJ.COM]

      1. 您可能在找
      2. 億恩北京公司:
      3. 經營性ICP/ISP證:京B2-20150015
      4. 億恩鄭州公司:
      5. 經營性ICP/ISP/IDC證:豫B1.B2-20060070
      6. 億恩南昌公司:
      7. 經營性ICP/ISP證:贛B2-20080012
      8. 服務器/云主機 24小時售后服務電話:0371-60135900
      9. 虛擬主機/智能建站 24小時售后服務電話:0371-60135900
      10. 專注服務器托管17年
        掃掃關注-微信公眾號
        0371-60135900
        Copyright© 1999-2019 ENKJ All Rights Reserved 億恩科技 版權所有  地址:鄭州市高新區翠竹街1號總部企業基地億恩大廈  法律顧問:河南亞太人律師事務所郝建鋒、杜慧月律師   京公網安備41019702002023號
          1
         
         
         
         

        0371-60135900
        7*24小時客服服務熱線

         
         
        av不卡不卡在线观看_最近2018年中文字幕_亚洲欧美一区二区三区_一级A爱做片免费观看国产_日韩在线中文天天更新_伊人中文无码在线