`

mysql 触发器学习

阅读更多

1. 一个简单的例子

1.1. 创建表:

   create table t(s1 integer);

1.2. 触发器:

delimiter |
create trigger t_trigger before insert on 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 |
createtrigger pseudohash_crc_ins before inserton pseudohash for each row
beginset@x= "hello trigger";
set NEW.url_crc=crc32(NEW.url);
end;
|
createtrigger pseudohash_crc_upd before updateon pseudohash for each row
beginset@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存储引擎

     

CREATETABLE `urls` (
`url`
varchar(255) DEFAULTNULL,
`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

       (允许存储程序通过参数将数据返回触发程序)。 

          而存储过程  可以接受参数,将结果范围给应用程序

分享到:
评论

相关推荐

    mysql触发器之触发器的增删改查操作示例

    MySQL触发器是数据库管理系统提供的一种机制,用于在特定的数据操作(如INSERT、UPDATE、DELETE)发生之前或之后自动执行预定义的SQL语句。这些触发器可以用来实现复杂的业务规则,确保数据的一致性和完整性,或者...

    mysql触发器+存储过程

    文件“MySQL存储过程.pdf”和“OReilly.MySQL.Stored.Procedure.Programming.rar”可能会提供关于如何创建、调用和管理MySQL存储过程的详细指南,而“MySQL触发器.rar”则可能包含触发器的创建、使用和优化方面的...

    MySQL触发器.rar

    在"MySQL触发器.pdf"这本书籍教程中,你可能会深入学习到触发器的详细用法,包括如何创建、修改和删除触发器,以及如何在实际项目中有效利用它们。"下载说明.txt"可能包含了获取更多资源的指引,而"A5下载- 更全的...

    MySQL触发器学习总结

    MySQL触发器是数据库管理系统提供的一种机制,允许在特定的数据操作(如INSERT、UPDATE或DELETE)发生时自动执行一些预定义的SQL语句。在本例中,我们关注的是`AFTER INSERT`触发器,它在向`order`表中插入新记录后...

    mysql触发器.zip

    MySQL触发器是数据库管理系统中的一个重要特性,它允许在特定的数据库操作...通过学习这些资料,开发者和数据库管理员能够更好地理解和掌握MySQL触发器的用法,从而在设计数据库系统时更加灵活和高效地实施业务规则。

    mysql触发器.pdf

    在本文件中,我们将会学习到关于MySQL触发器的创建、应用以及如何查看触发器等知识点。 ### 触发器的定义和作用 触发器用于在执行INSERT、UPDATE或DELETE等SQL语句时自动执行一段代码(即触发器体)。它是对数据库...

    mysql 触发器文档

    通过本文档的学习,您已经掌握了触发器的基本概念及其创建方法,并了解了如何利用触发器实现常见的数据完整性和审计需求。 #### 关于MySQL MySQL是一款广泛使用的开源关系型数据库管理系统,因其高效、可靠和易于...

    MySQL 5.0 触发器.rar

    在学习和使用MySQL 5.0触发器的过程中,你可以参考提供的书籍教程《MySQL 5.0 触发器》。这本书可能涵盖了触发器的基础概念、创建和管理触发器的方法、示例应用以及最佳实践。同时,文件`下载说明.txt`可能包含获取...

    MySQL触发器运用于迁移和同步数据的实例教程

    初始的MySQL触发器设计会导致死循环,因为更新操作会再次触发触发器,形成无限递归。为了解决这个问题,我们需要将触发器设置为在操作之前执行(BEFORE),这样在数据被实际写入表之前就完成分类计算,避免了死循环...

    MySQL触发器代码

    ### MySQL触发器详解 #### 一、触发器概念与作用 触发器是一种存储过程,它定义了一组SQL语句,并且被设计成自动响应特定事件(如数据的修改)。触发器通常用于强化复杂的业务规则或者数据完整性约束。它们可以在...

    mysql的触发器教程和示例代码

    通过学习`MYSQL触发器教程.doc`和查阅`data-550830.pdf`中的内容,你可以深入理解触发器的工作原理,掌握创建和管理触发器的方法,并在实际项目中灵活应用。请根据这些资源进一步学习和实践,以便更好地掌握MySQL...

    MySQL触发器:数据完整性的守护者

    - **易于使用**:MySQL提供了简单直观的界面和丰富的文档,便于用户学习和使用。 - **可扩展性**:MySQL支持从小型应用到大型企业级应用的扩展。 - **社区支持**:由于其广泛的使用,MySQL拥有一个活跃的开发者社区...

    mysql学习资料大全

    这份"mysql学习资料大全"包含了一系列的资源,对于想要学习或深入理解MySQL的人来说,是一份非常宝贵的资料集。 首先,从标题我们可以推断,这份资料可能涵盖了MySQL的基础到进阶内容,包括安装配置、SQL语言基础、...

    MySQL数据库函数,触发器,存储过程

    通过深入学习和掌握MySQL的函数、触发器和存储过程,开发者能够更加高效地管理和操作数据库,解决复杂的数据处理问题,提升应用程序的性能。在实际项目中,熟练运用这些特性是数据库设计和优化的关键。通过"mysql...

    MySQL从入门到实战学习教程之11触发器.pptx

    MySQL触发器知识点 MySQL触发器是指在预定义的事件发生时自动执行的特殊存储过程。触发器可以与表事件相关,例如Insert、Update或Delete事件。触发器可以基于一个表创建,但是可以针对一个或多个表进行操作。触发器...

    MySQL触发器(教程).md

    一起学习讨论, 0分资源, 随便下

    MYSQL学习资料

    mysql 触发器 mysql与MongoDB语法对比 mysql分表的3种方法 MySQL数据库扩展小记 mysql架构方案 MySQL水平分区表实际操作总结 Mysql水平分表 mysql水平分表和垂直分表和数据库分区 sysbench mysql 坚持不懈 sysbench...

    非常详细的某培训机构mysql学习笔记

    MySQL触发器 MySQL存储过程与函数 MySQL3 MySQL安全机制 MySQL日志管理 MySQL数据备份 备份概述 mysqldump [逻辑] mydumper [逻辑] into outfile [逻辑] xtrabackup [物理] snapshot [物理] tar打包...

    mysql 触发器语法与应用示例

    MySQL触发器是数据库管理系统中的一个重要特性,它允许在特定的数据操作(如INSERT、UPDATE或DELETE)发生时自动执行预定义的SQL语句。这为数据库的业务逻辑提供了强大的支持,可以确保数据的一致性和完整性。以下是...

Global site tag (gtag.js) - Google Analytics