微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

SQL触发器的作用是什么

本篇文章为大家展示了sql触发器的作用是什么,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

触发器的作用

  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是会自动从小到大排序,加锁也是一条条从小到大加的锁

上述内容就是sql触发器的作用是什么,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注编程之家行业资讯频道。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐