Java学习者论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

手机号码,快捷登录

恭喜Java学习者论坛(https://www.javaxxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,购买链接:点击进入购买VIP会员
JAVA高级面试进阶视频教程Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程

Go语言视频零基础入门到精通

Java架构师3期(课件+源码)

Java开发全终端实战租房项目视频教程

SpringBoot2.X入门到高级使用教程

大数据培训第六期全套视频教程

深度学习(CNN RNN GAN)算法原理

Java亿级流量电商系统视频教程

互联网架构师视频教程

年薪50万Spark2.0从入门到精通

年薪50万!人工智能学习路线教程

年薪50万!大数据从入门到精通学习路线年薪50万!机器学习入门到精通视频教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程 MySQL入门到精通教程
查看: 341|回复: 0

[默认分类] mysql 触发器学习

[复制链接]
  • TA的每日心情
    开心
    2021-12-13 21:45
  • 签到天数: 15 天

    [LV.4]偶尔看看III

    发表于 2018-7-10 13:31:35 | 显示全部楼层 |阅读模式
    1. 一个简单的例子
    1.1. 创建表:
       create table t(s1 integer);
    1.2. 触发器:

    1. delimiter |
    2. create trigger t_trigger before insert on t  for each row
    3. begin set @x = "hello trigger";
    4.        set NEW.s1 = 55;
    5. end;
    6. |
    复制代码

    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 创建触发器,当对表进行插入和更新时,触发 触发器

    1. delimiter |
    2. create trigger pseudohash_crc_ins before insert on pseudohash  for each row
    3. begin set @x = "hello trigger";
    4.        set NEW.url_crc=crc32(NEW.url);
    5. end;
    6. |
    7. create trigger pseudohash_crc_upd before update on pseudohash  for each row
    8. begin set @x = "hello trigger";
    9.        set NEW.url_crc=crc32(NEW.url);
    10. end;
    11. |
    12. 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存储引擎
         

    1. CREATE TABLE `urls` (
    2.   `url` varchar(255) DEFAULT NULL,
    3.   `url_crc` int(11) DEFAULT "0",
    4.   KEY `url` (`url`) USING HASH
    5. ) 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
    1.               ON tbl_name FOR EACH ROW trigger_stmt
    复制代码
    trigger_time是触发程序的动作时间。它可以是BEFORE或AFTERtrigger_event指明了激活触发程序的语句的类型。trigger_event可以是下述值之一:
    1. ·             INSERT:将新行插入表时激活触发程序,例如,通过INSERT、LOAD DATA和REPLACE语句。
    2. ·             UPDATE:更改某一行时激活触发程序,例如,通过UPDATE语句。
    3. ·             DELETE:从表中删除某一行时激活触发程序,例如,通过DELETE和REPLACE语句。
    复制代码
    1.       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
    1.        (允许存储程序通过参数将数据返回触发程序)。
    复制代码
              而存储过程  可以接受参数,将结果范围给应用程序
    1.    
    复制代码
             
          
          
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|Java学习者论坛 ( 声明:本站资料整理自互联网,用于Java学习者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2024-3-29 03:34 , Processed in 0.369142 second(s), 37 queries .

    Powered by Discuz! X3.4

    © 2001-2017 Comsenz Inc.

    快速回复 返回顶部 返回列表