MySQL触发器、存储过程

一个简单的例子

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

       (允许存储程序通过参数将数据返回触发程序)。
          而存储过程  可以接受参数,将结果范围给应用程序
 
 
  MySQL触发器、存储过程、自定义函数、视图简单示例 

0.test数据库有userinfo用户信息表 和userinfolog用户信息日志表
1.建立一个userinfo表新增记录时的触发器 将新增日志加入到userinfolog
2.建立一个向userinfo表新增记录的存储过程
3.根据userinfo表的出生日期字段 我们将建立一个简单算得年龄的自定义函数
4.创建一个userinfo的视图 调用年龄函数
-------------
0.准备相关表
mysql> use test;
mysql> create table userinfo(userid int,username varchar(10),userbirthday date);
mysql> create table userinfolog(logtime datetime,loginfo varchar(100));
mysql> describe userinfo;
1.触发器
mysql> delimiter |
mysql> create trigger beforeinsertuserinfo
    -> before insert on userinfo
    -> for each row begin
    ->   insert into userinfolog values(now(),CONCAT(new.userid,new.username));
    -> end;
    -> |
mysql> delimiter ;
mysql> show triggers;
2.存储过程
mysql> delimiter //
mysql> create procedure spinsertuserinfo(
    -> puserid int,pusername varchar(10)
    -> ,puserbirthday date
    -> )
    -> begin
    ->  insert into userinfo values(puserid,pusername,puserbirthday);
    -> end;
    -> //
mysql> show procedure status like 'spinsertuserinfo';
mysql> call spinsertuserinfo(1,'zhangsan',current_date);
mysql> select * from userinfo;

3.自定义函数
mysql> update userinfo
    -> set userbirthday='2000.01.01'
    -> where userid='1';
mysql> drop function if exists fngetage;
mysql> delimiter //
mysql> create function fngetage(pbirthday date)
    -> returns integer
    -> begin
    ->  return year(now()) - year(pbirthday);
    -> end
    -> //
4.视图
mysql> create view viewuserinfo
    -> as select * ,fngetage(userbirthday) as userage from userinfo;
mysql> select * from viewuserinfo;
清除日志记录
mysql> truncate table userinfolog;
mysql> delete from userinfolog;MySQL触发器、存储过程

你可能感兴趣的:(MySQL触发器、存储过程)