现在的位置: 首页 > 数据库 > 正文

SQL触发器的作用有哪些

2019年12月12日 数据库 ⁄ 共 872字 ⁄ 字号 评论关闭

  MySQL触发器的作用是可以跟踪用户对数据库的操作,实现复杂的非标准的数据库相关完整性规则,能够同步实时的复制表中的数据以及自动计算数据值等


  触发器


  触发器是一种特殊的存储过程,它在试图更改触发器所保护的数据时自动执行。


  

触发器的作用


  1、安全性,可以基于数据库的值使用户具有操作数据库的某种权利。


  2、审计,可以跟踪用户对数据库的操作。


  3、实现复杂的非标准的数据库相关完整性规则,触发器可以对数据库中相关的表进行连环更新。


  4、触发器能够拒绝或回退那些破坏相关完整性的变化,取消试图进行数据更新的事务。当插入一个与其主健不匹配的外部键时,这种触发器会起作用。


  5、同步实时地复制表中的数据


  6、自动计算数据值,如果数据的值达到了一定的要求,则进行特定的处理。


  mysql中死锁:是指两个或两个以上的进程在执行过程中,因争夺资源而造成的一种互相等待的现象,若无外力作用,它们都将无法推进下去.此时称系统处于死锁状态或系统产生了死锁,这些永远在互相等待的进程称为死锁进程。表级锁不会产生死锁.所以解决死锁主要还是针对于最常用的InnoDB。


  死锁的关键在于:两个(或以上)的Session加锁的顺序不一致。


  那么对应的解决死锁问题的关键就是:让不同的session加锁有次序


  

mysql中死锁案例


  需求:将投资的钱拆成几份随机分配给借款人。


  起初业务程序思路是这样的:


  投资人投资后,将金额随机分为几份,然后随机从借款人表里面选几个,然后通过一条条select for update 去更新借款人表里面的余额等。


  例如两个用户同时投资,A用户金额随机分为2份,分给借款人1,2


  B用户金额随机分为2份,分给借款人2,1


  由于加锁的顺序不一样,死锁当然很快就出现了。


  对于这个问题的改进很简单,直接把所有分配到的借款人直接一次锁住就行了。


  Select * from xxx where id in (xx,xx,xx) for update


  在in里面的列表值mysql是会自动从小到大排序,加锁也是一条条从小到大加的锁

抱歉!评论已关闭.