当前位置:天才代写 > tutorial > 数据库教程 > 三分钟学会mysql触发器操作

三分钟学会mysql触发器操作

2018-05-20 08:00 星期日 所属: 数据库教程 浏览:330

  今天给大家一个例子,让大家学习什么是MySQL的触发器?当mysql触发器发生创建错误时,怎样解决?关于触发器的语法又有哪些需要注意的地方?mysql数据库触发器该怎样进行存储?

三分钟学会mysql触发器操作_数据库_mysql存储_课课家

  1.一个简单的例子

  1.1.创建表:

  createtablet(s1integer);

  1.2.触发器:

三分钟学会mysql触发器操作

  1.3.如果触发器创建错误,可能只能删除了,至少我试过不能replace

  droptriggert_trigger;

  1.4.当执行insert时:

  insertintotvalues(1);

  1.5.会执行触发器t_trigger

  select@x,t.*fromt;

  1.6.可以看到结果:

三分钟学会mysql触发器操作

  1.7可以使用SHOWTRIGGERS;查看新建的触发器

  2.url查询哈希值的维护触发器

  2.1创建表PSeudohash。

三分钟学会mysql触发器操作

  2.2创建触发器,当对表进行插入和更新时,触发触发器

  复制代码

三分钟学会mysql触发器操作

  复制代码

  2.3插入操作

三分钟学会mysql触发器操作

  2.4查看表中数据(是进行更新操作之后的数据)

三分钟学会mysql触发器操作

  2.5更新

三分钟学会mysql触发器操作

  2.6上面源于一个对于url建立索引的例子,还有一种建立索引的方式:在B+树上建立一个伪索引,和真正的索引不同,它还是在B+树索引上进行查找,但是,使用的是键的哈希值进行查找,而不是键本身,这样会加快查找

  2.6.1创建urls表,注意使用的是memory存储引擎

三分钟学会mysql触发器操作

  2.6.2然后插入url和url_crc,例如

  insertintourlsvalues('www.gougou.com',crc32('www.gougou.com'));

  像上面的那样,或者使用触发器

  2.6.3然后查询的时候使用hash索引查询

三分钟学会mysql触发器操作

  上面3个查询结果当然是一样的,但是速度上hash的快很多

  3.触发器语法

  3.1CREATETRIGGERtrigger_nametrigger_timetrigger_event

  ONtbl_nameFOREACHROWtrigger_stmt

  trigger_time是触发程序的动作时间。它可以是BEFORE或AFTERtrigger_event指明了激活触发程序的语句的类型。trigger_event可以是下述值之一:

  ·INSERT:将新行插入表时激活触发程序,例如,通过INSERT、LOADDATA和REPLACE语句。

  ·UPDATE:更改某一行时激活触发程序,例如,通过UPDATE语句。

  ·DELETE:从表中删除某一行时激活触发程序,例如,通过DELETE和REPLACE语句。

  3.2可能遇到的问题

  如果你在触发器里面对刚刚插入的数据进行了insert/update,会造成循环的调用.

  如:

  createtriggertestbeforeupdateontestforeachrowupdatetestsetNEW.updateTime=NOW()whereid=NEW.ID;END

  应该使用set:

  createtriggertestbeforeupdateontestforeachrowsetNEW.updateTime=NOW();END

  3.3触发器与存储过程

  触发程序不能调用将数据返回客户端的存储程序,也不能使用采用CALL语句的动态SQL

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

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

 

    关键字:

天才代写-代写联系方式