mysql 觸發器學習

來源:互聯網
上載者:User

1. 一個簡單的例子

1.1. 建立表:

   create table t(s1 integer);

1.2. 觸發器:

delimiter |create trigger t_trigger before insert on t  for each row begin set @x = "hello trigger";       set NEW.s1 = 55;end; |

1.3. 如果觸發器建立錯誤,可能只能刪除了,至少我試過不能replace

   drop trigger t_trigger;

1.4. 當執行insert 時:

   insert into t values(1);

1.5. 會執行觸發器t_trigger

   select @x,t.* from t; 

1.6. 可以看到結果:

    

1.7可以使用 SHOW TRIGGERS; 查看建立的觸發器

2. url查詢雜湊值的維護 觸發器

    2.1 建立表 pseudohash。

2.2 建立觸發器,當對錶進行插入和更新時,觸發 觸發器

delimiter |
create trigger pseudohash_crc_ins before insert on pseudohash for each row
begin set @x = "hello trigger";
set NEW.url_crc=crc32(NEW.url);
end;
|
create trigger pseudohash_crc_upd before update on pseudohash for each row
begin set @x = "hello trigger";
set NEW.url_crc=crc32(NEW.url);
end;
|

delimiter ;

  2.3 插入操作

     insert into pseudohash(url) values("http://www.baidu.com");

     insert into pseudohash(url) values("http://www.163.com");

     2.4 查看錶中資料(是進行更新操作之後的資料)

    2.5 更新

   update pseudohash set url = 'www.163.com' where id = 1;

   可以看到的是,插入和更新操作後,他們的 url_crc是不同的 

----------------------------------------------------------------------------

    2.6  上面源於一個 對於url建立索引的例子,還有一種建立索引的方式: 在B+ 型樹狀結構上建立一個虛擬索引,和真正的索引不同,它還是在B+樹 索引上進行尋找,但是,使用的是 鍵的雜湊值進行尋找,而不是鍵本身,這樣會加快尋找

         2.6.1 建立urls 表,注意使用的是 memory儲存引擎

     

CREATE TABLE `urls` (
`url` varchar(255) DEFAULT NULL,
`url_crc` int(11) DEFAULT '0',
KEY `url` (`url`) USING HASH
) ENGINE=MEMORY DEFAULT CHARSET=utf8;

     2.6.2 然後插入url和url_crc,例如

        insert into urls values('www.gougou.com',crc32('www.gougou.com'));

        像上面的那樣,或者使用觸發器

        2.6.3 然後查詢的時候使用 hash索引查詢

       select * from urls where url = "www.baidu.com" and url_crc = crc32("www.baidu.com"); 

       select * from urls where url_crc = crc32("www.baidu.com"); 

       select * from urls where url = "www.baidu.com"

      上面3個查詢結果當然是一樣的,但是速度上hash的快很多

3. 觸發器 文法

    3.1  CREATE TRIGGER trigger_name trigger_time trigger_event

              ON tbl_name FOR EACH ROW trigger_stmt

trigger_time是觸發程式的動作時間。它可以是BEFORE或AFTERtrigger_event指明了啟用觸發程式的語句的類型。trigger_event可以是下述值之一:

·             INSERT:將新行插入表時啟用觸發程式,例如,通過INSERT、LOAD DATA和REPLACE語句。·             UPDATE:更改某一行時啟用觸發程式,例如,通過UPDATE語句。·             DELETE:從表中刪除某一行時啟用觸發程式,例如,通過DELETE和REPLACE語句。
      3.2 可能遇到的問題

            如果你在觸發器裡面對剛剛插入的資料進行了 insert/update, 會造成迴圈的調用.

            如:

             create trigger test before update on test for each row update test set NEW.updateTime = NOW() where id=NEW.ID; END

            應該使用set:

            create trigger test before update on test for each row set NEW.updateTime = NOW(); END

     3.3 觸發器 與預存程序

           觸發程式不能調用將資料返回用戶端的儲存程式,也不能使用採用CALL語句的動態SQL

       (允許儲存程式通過參數將資料返回觸發程式)。 

          而預存程序  可以接受參數,將結果範圍給應用程式

    

          

      

       

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.