在触发思考

在触发思考

大家好,又见面了,我是全栈君,今天给大家准备了Idea注册码。

        读到周洲同学的博客,看到一篇关于触发器的文章,是在用户充值时,须要在t_reCharge表中插入一条记录,同一时候更新t_card表以保证数据一致性.我们当时没想特别多,没想到触发器,就是写了多条sql语句,为了不出错后来使用了事务或存储过程,没记错的话是放在存储过程里了。她是这么实现的:

 

“recharge表中保证提取的是最新一条充值记录,card表中保证更新的记录满足卡号等于充值卡号。”

 

<spanstyle="font-family:FangSong_GB2312;">CREATETRIGGER[dbo].[CardCash]  on [dbo].[T_Recharge]  for Insert AS  BEGIN  UPDATE T_Card set sCash  =sCash +(select top 1 rAdd  fromT_Recharge order by rNo desc) WhereT_Card .cNo in (select top 1 cNo  fromT_Recharge order by rNo desc )    END</span>

 

原文链接例如以下: 

                       给D层减负-存储过程与触发器的使用

 

看到这儿,心里挺佩服小师妹的,只是我还有两个问题:

1. sql语句是硬伤,我可不能够传參呢?

2. 假设有两个卡同一时候充值,会不会查询到的t_reCharge最新记录是还有一个卡的?换句话说,update和insert孰先孰后?事实上我一直也没想明确两个卡同一时候充值究竟先插入哪条记录?

3. 假设2中的触发器本身就是事务,保证了要么都运行要么都不运行,就没有这个问题.否则,是不是考虑加上事务呢?

 

        接下来进一步了解了触发器的工作原理。

        因为使表中数据发生变化的操作有插入、更新和删除,所以触发器能够分为三类:INSERT触发器、UPDATE触发器和DELETE触发器。

1.INSERT触发器

当试图向表中插入记录时,INSERT触发器(假设有)自己主动运行,此时系统自己主动创建一个inserted表。新的记录被加入到触发器表和inserted表。触发器能够检查inserted表,确定是否运行触发器动作和怎样运行触发器动作。

2.DELETE触发器

当试图从表中删除信息时,DELETE触发器被触发。此时系统自己主动创建一个deleted表,被删除的行被放置到这个特殊的表中。

被删除的行在触发器表中将不再存在。因此,触发器表和deleted表之间没有共同的记录。

3.UPDATE触发器

UPDATE语句能够看成两步。删除一条旧记录。插入一条新记录。所以。UPDATE触发器被触发时,自己主动创建一个deleted表和一个inserted表,UPDATE语句使原始行移入deleted表,将更新行插入到inserted表中。

 

        我们这里是一个insert触发器,那为什么用触发器?用一个类似的样例来解释。

我们有两个表用来记录商品的出库入库情况。t_good_store记录库存的产品类别和数量,而t_good_out记录出库的产品类别和数量,那么每当我们出库的某个类别的产品一定数量的时候,我们应该在t_good_out中插入该产品的类别和出库数量。同一时候也应该在t_good_store中用update来更新库存的对应类别的产品的数量。这时我们要完毕两个任务:插入t_good_out后更新t_good_store,为避免仅仅操作当中一个而造成数据的不一致,我们能够用触发器,在t_good_out的插入操作上绑定一个对t_good_store更新的触发器。当然这个过程应该是一个事务,这就不必操心插入t_good_out表运行了,而绑定在这个动作上的触发器操作不会运行。由于数据库设计了原子性。

 

      再来看上面的三个问题.

1. 触发器仅仅有在改动(包含插入和删除)时触发,目的是给我们一个做其它动作的机会,它没有在查询数据时做其它动作的能力.问了触发器是否有參数这个问题,说明我刚開始没有理解触发器的这个特性.

另外,依据触发器的工作原理,我们能够訪问inserted和deleted这两张暂时表,须要明确的是inserted存放进行insert和update操作后的数据;deleted存放进行delete和update操作前的数据.

Update=delete+insert.这一点给我们的启发:DRP系统中有一个页面是改动Item或者client或者flowCard,能够先都删除再都插入,然后提示改动成功,不然那个样子多的条目,怎样一条条推断再modify?

2. 关于同一时候插入两个记录,有人说能够,由于insert是在毫秒级,可是无论什么级都是有先有后啊.又说,insert是rowlevel锁,假设不Lock table的话,也无法确定先后啊.

3. 我觉得能够不加事务,触发器要是设计得insert和update之间还能够容得下其它操作,那就没有什么意义了.

 

        我先实验一把,这个空当,就算抛砖引玉了,当然也会默默地、虚心地接受板砖…

版权声明:本文博主原创文章,博客,未经同意不得转载。

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

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/117075.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 茂名重力石化装备股份公司_恒力石化二期项目批复

    茂名重力石化装备股份公司_恒力石化二期项目批复目前来看,广东省已经拥有诸多国外化工巨头、大型民营炼化企业和不少国企的炼化项目,成为很多石化企业首选的项目落地基地。“石化业高质量发展看广东”,已经逐渐明朗。今年3月31日,广东省发展改革委官网公布《广东省2021年重点建设项目计划》。在2021年重点项目名单中,广东共安排省重点项目1395个,总投资达7.28万亿元,年度计划投资8000亿元。其中新开工项目有3个,总投资约267亿元,年度投资约60.5亿元,分别是恒力石化(惠州)PTA项目、东华能源(茂名)烷烃资源综合利用项目.

    2022年10月10日
    2
  • python读取、写入txt文本内容

    python读取、写入txt文本内容读取txt文本python常用的读取文件函数有三种read()、readline()、readlines()以读取上述txt为例,看一下三者的区别read()一次性读全部内容一次性读取文本中全部的内容,以字符串的形式返回结果withopen(“test.txt”,”r”)asf:#打开文件data=f.read()#读取文件…

    2022年6月2日
    58
  • 数据结构面试经典问题汇总及答案_数据结构基础面试题

    数据结构面试经典问题汇总及答案_数据结构基础面试题数据结构面试经典问题汇总参考资源:基础深入补充:参考资源:基础数据结构常见面试题深入数据结构面试题(三)数据结构面试必问数据结构算法常见面试考题补充:1.数组和链表的区别,请详细解释。从逻辑结构来看:a)数组必须事先定义固定的长度(元素个数),不能适应数据动态地增减的情况。当数据增加时,可能超出原先定义的元素个数;当数据减少时,造成内存浪费;数组可以根据下标直接存取。b)链表动态地进行存储分配,可以适应数据动态地增减的情况,且可以方便地插入、删除数据项。(数组中插入、删除

    2022年9月19日
    3
  • margin的使用方法与技巧

    1.margin还可以用来做平移,作用类似translate哈哈。将元素设成absolute后就可以用margin随便平移他了,既不像relative那样要霸占空间,又不用为父元素设置relative

    2021年12月20日
    52
  • pycharm 激活码2021年【在线破解激活】

    pycharm 激活码2021年【在线破解激活】,https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月16日
    54
  • java case when用法_sql case when 嵌套

    java case when用法_sql case when 嵌套前几天在客户环境遇到一个Spark“CASEWHEN”语句的性能优化问题。客户那边通过一个“时间范围筛选”控件来动态修改图表的数据。其很多指标的计算逻辑类似于:CASEWHEN`bizdate`BETWEEN’2020-09-06’AND’2020-09-13’THEN`sales_amount`ELSE0ENDCASEWHEN语句有些类似于编程语言中的Switch语句,当这里的…

    2025年9月18日
    5

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号