数据库触发器(Trigger)的一点使用心得

 更新时间:2009年07月27日 18:18:29   作者:  
最近了解了一下数据库触发器,并做一点实际的应用,在翻看其概念的时候,还是本着从理解的角度来学习的,但是,到了实际的应用场景中,还是有一些特别注意的地方的,下面是自己在应用中的几点体会
(1) 针对较为复杂的跨多表的数据业务级别的约束,可以通过触发器来替代大量的后台判断代码,效率较高且便捷。
(2) 如果想通过触发器辅助业务逻辑,不能单着眼于数据库内容的变化来设计触发器,还必须紧密结合业务模型中涉及该表的所有地方,因为很有可能因为不一致的逻辑处理方式导致我们设计的触发器遗漏下一些分支条件!其实,在这种情况下,如果能有更好的方法,不建议使用触发器,因为牵扯到过多的业务逻辑内容的话,会使触发器的设计和编写困难重重,不能充分发挥其便捷高效的优点。
(3) 鉴于触发器在实际运行的时候,是被包含在一个数据库事务中的,所以我们在编写了完整的处理分支后,就可以完全信赖它的执行,大量并发情况下,数据库会自动处理好对各事务的操作,不用担心触发器的性能和正确性。
(4) 在同一个事务中的不同执行语句,如果后面语句中的操作触发了相应表的触发器,则在触发器内可以查看前面语句执行后的结果列表的内容,所以,在使用触发器的时候,对事物中多条语句的操作的顺序是要考虑清楚的。
(5) 如果我们使用触发器+数据表的形式来对数据进行一些统计性的操作的时候,我们在保证触发器逻辑完整性的前提下,最好能通过数据库任务的方式来定时进行检查,因为触发器对于一个用程序的操作都能有相应的处理,但对于人为的数据库操作有时却是无能为力的,所以,为了避免这样的错误发生,有必要对统计结果做定期的校验,保证数据的正确性,当然,如果可以,尽量不要使用这种方法,但在一些个性化项目中,因为一些特别的原因,可能会有所应用。
(6) 我们可以间接地通过更新数据表的方式来调试触发器,当然,也可以通过在触发器中添加一些“特殊的日志性质的更新语句”来辅助我们的调试。

最后再说一句,所谓“好钢用在刀刃上”,触发器在一些特殊的应用情况下,会极大地简化我们的开发工作量,并提升处理效率,但是它并使万能的,也不是适用于各种应用环境,所以我们使用的时候,一定要慎重,更要权衡利弊。

相关文章

  • 将sqlite3中数据导入到mysql中的实战教程

    将sqlite3中数据导入到mysql中的实战教程

    最近因为工作的需求,需要将sqlite3中的数据导入到mysql中去,发现网上的一些教程都不够详细,索性自己写一篇,下面这篇文章主要给大家介绍了关于将sqlite3数据库中的数据导入到mysql数据库中的相关资料,需要的朋友可以参考下。
    2017-07-07
  • SQL 查询语句积累

    SQL 查询语句积累

    SQL 查询语句积累...
    2006-12-12
  • 通过navicat导入sql文件的操作方法

    通过navicat导入sql文件的操作方法

    在很多项目当中都有sql文件导入到MySQL数据库的需要,因为有sql数据库文件,这个项目才能正常运行起来,那么现在就来学习一下怎么导入sql文件到navicat里面吧,需要的朋友可以参考下
    2024-03-03
  • 当数据库变慢时的解决方法

    当数据库变慢时的解决方法

    当数据库变慢时,我们应如何入手,下面的解决方法。
    2009-04-04
  • SQL实现分页查询方法总结

    SQL实现分页查询方法总结

    这篇文章介绍了SQL实现分页查询方法总结,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-12-12
  • 一个多表查询的SQL语句

    一个多表查询的SQL语句

    一个多表查询的SQL语句...
    2007-06-06
  • 通过DBeaver连接Phoenix操作hbase的方法

    通过DBeaver连接Phoenix操作hbase的方法

    DBeaver 可通过 JDBC 连接到数据库,可以支持几乎所有的数据库产品,本文介绍常用一种通用数据库工具Dbeaver,通过DBeaver连接Phoenix操作hbase的操作,需要的朋友跟随小编一起看看吧
    2021-11-11
  • 一款免费开源的通用数据库工具DBeaver

    一款免费开源的通用数据库工具DBeaver

    这篇文章主要介绍了一款免费开源的通用数据库工具DBeaver,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-10-10
  • Navicat for MySQL导入csv文件时出现中文乱码的问题解决

    Navicat for MySQL导入csv文件时出现中文乱码的问题解决

    在做数据对接导入的时候使用的数据是CSV格式的文件,导入发现了乱码,下面这篇文章主要给大家介绍了关于Navicat for MySQL导入csv文件时出现中文乱码的问题解决办法,需要的朋友可以参考下
    2023-12-12
  • 数据库的ACID特性术语详解

    数据库的ACID特性术语详解

    这篇文章主要介绍了数据库的ACID特性术语详解,ACID就是:原子性(Atomicity )、一致性( Consistency )、隔离性( Isolation)和持久性(Durabilily),本文分别解释了它们,需要的朋友可以参考下
    2015-02-02

最新评论