九色国产,午夜在线视频,新黄色网址,九九色综合,天天做夜夜做久久做狠狠,天天躁夜夜躁狠狠躁2021a,久久不卡一区二区三区

打開(kāi)APP
userphoto
未登錄

開(kāi)通VIP,暢享免費(fèi)電子書等14項(xiàng)超值服

開(kāi)通VIP
mysql 觸發(fā)器

1. 一個(gè)簡(jiǎn)單的例子

1.1. 創(chuàng)建表:

   create table t(s1 integer);

1.2. 觸發(fā)器:

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

1.3. 如果觸發(fā)器創(chuàng)建錯(cuò)誤,可能只能刪除了,至少我試過(guò)不能replace

   drop trigger t_trigger;

1.4. 當(dāng)執(zhí)行insert 時(shí):

   insert into t values(1);

1.5. 會(huì)執(zhí)行觸發(fā)器t_trigger

   select @x,t.* from t; 

1.6. 可以看到結(jié)果:

    

1.7可以使用 SHOW TRIGGERS; 查看新建的觸發(fā)器

2. url查詢哈希值的維護(hù) 觸發(fā)器

    2.1 創(chuàng)建表 pseudohash。

2.2 創(chuàng)建觸發(fā)器,當(dāng)對(duì)表進(jìn)行插入和更新時(shí),觸發(fā) 觸發(fā)器

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 查看表中數(shù)據(jù)(是進(jìn)行更新操作之后的數(shù)據(jù))

    2.5 更新

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

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

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

    2.6  上面源于一個(gè) 對(duì)于url建立索引的例子,還有一種建立索引的方式: 在B+ 樹(shù)上建立一個(gè)偽索引,和真正的索引不同,它還是在B+樹(shù) 索引上進(jìn)行查找,但是,使用的是 鍵的哈希值進(jìn)行查找,而不是鍵本身,這樣會(huì)加快查找

         2.6.1 創(chuàng)建urls 表,注意使用的是 memory存儲(chǔ)引擎

     

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'));

        像上面的那樣,或者使用觸發(fā)器

        2.6.3 然后查詢的時(shí)候使用 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個(gè)查詢結(jié)果當(dāng)然是一樣的,但是速度上hash的快很多

3. 觸發(fā)器 語(yǔ)法

    3.1  CREATE TRIGGER trigger_name trigger_time trigger_event

              ON tbl_name FOR EACH ROW trigger_stmt

trigger_time是觸發(fā)程序的動(dòng)作時(shí)間。它可以是BEFORE或AFTERtrigger_event指明了激活觸發(fā)程序的語(yǔ)句的類型。trigger_event可以是下述值之一:

·             INSERT:將新行插入表時(shí)激活觸發(fā)程序,例如,通過(guò)INSERT、LOAD DATA和REPLACE語(yǔ)句?!?            UPDATE:更改某一行時(shí)激活觸發(fā)程序,例如,通過(guò)UPDATE語(yǔ)句?!?            DELETE:從表中刪除某一行時(shí)激活觸發(fā)程序,例如,通過(guò)DELETE和REPLACE語(yǔ)句。
      3.2 可能遇到的問(wèn)題

            如果你在觸發(fā)器里面對(duì)剛剛插入的數(shù)據(jù)進(jìn)行了 insert/update, 會(huì)造成循環(huán)的調(diào)用.

            如:

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

            應(yīng)該使用set:

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

     3.3 觸發(fā)器 與存儲(chǔ)過(guò)程

           觸發(fā)程序不能調(diào)用將數(shù)據(jù)返回客戶端的存儲(chǔ)程序,也不能使用采用CALL語(yǔ)句的動(dòng)態(tài)SQL

       (允許存儲(chǔ)程序通過(guò)參數(shù)將數(shù)據(jù)返回觸發(fā)程序)。 
          而存儲(chǔ)過(guò)程  可以接受參數(shù),將結(jié)果范圍給應(yīng)用程序
本站僅提供存儲(chǔ)服務(wù),所有內(nèi)容均由用戶發(fā)布,如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊舉報(bào)。
打開(kāi)APP,閱讀全文并永久保存 查看更多類似文章
猜你喜歡
類似文章
觸發(fā)器 隨寫
MySQL索引之哈希索引
觸發(fā)器怎么寫
mysql-操作觸發(fā)器
[轉(zhuǎn)]在oracle下觸發(fā)器實(shí)現(xiàn)主鍵自增
SQL觸發(fā)器的一點(diǎn)心得
更多類似文章 >>
生活服務(wù)
熱點(diǎn)新聞
分享 收藏 導(dǎo)長(zhǎng)圖 關(guān)注 下載文章
綁定賬號(hào)成功
后續(xù)可登錄賬號(hào)暢享VIP特權(quán)!
如果VIP功能使用有故障,
可點(diǎn)擊這里聯(lián)系客服!

聯(lián)系客服