zoukankan      html  css  js  c++  java
  • SQLSERVER触发器 天高地厚

    1、触发器。

      定义: 何为触发器?在SQL Server里面也就是对某一个表的一定的操作,触发某种条件,从而执行的一段程序。触发器是一个特殊的存储过程。
      常见的触发器有三种:分别应用于Insert , Update , Delete 事件。(SQL Server 2000定义了新的触发器,这里不提)

      我为什么要使用触发器?
        比如,这么两个表:
      Create Table Student(         --创建学生表
        StudentID int primary key,     --学号,定义主键约束
        ....
        )

      Create Table BorrowRecord(         --创建借书记录表
        BorrowRecord int identity(1,1),     --自动增长流水号 
        StudentID   int ,             --学号
        BorrowDate   datetime,           --借出时间
        ReturnDAte   Datetime,           --归还时间
        ...
      )

      用到的功能有:
        1.如果我更改了学生的学号,我希望他的借书记录仍然与这个学生相关(也就是同时更改借书记录表的学号);
        2.如果该学生已经毕业,我希望删除他的学号的同时,也删除它的借书记录。
      等等。

      这时候可以用到触发器。对于1,创建一个Update触发器:

      Create Trigger truStudent
        On Student
        for Update   --触发器类型--Update
      -------------------------------------------------------
       --Memo : 临时写写的,给大家作个Sample。没有调试阿。
      -------------------------------------------------------
      As
        if Update(StudentID)
        begin

        Update BorrowRecord 
          Set br.StudentID=i.StudentID
          From BorrowRecord br , Deleted d ,Inserted i 
          Where br.StudentID=d.StudentID

        end     
              
      理解触发器里面的两个临时的表:Deleted , Inserted 。注意Deleted 与Inserted分别表示触发事件的表“旧的一条记录”和“新的一条记录”。
      一个Update 的过程可以看作为:生成新的记录到Inserted表,复制旧的记录到Deleted表,然后删除Student记录并写入新纪录。

      对于2,创建一个Delete触发器
      Create trigger trdStudent
          On Student
          for Delete
      -------------------------------------------------------
      --Memo : 临时写写的,给大家作个Sample。没有调试阿。
      -------------------------------------------------------
      As
        Delete BorrowRecord 
        From BorrowRecord br , Delted d
        Where br.StudentID=d.StudentID

      从这两个例子我们可以看到了触发器的关键:A.2个临时的表;B.触发机制。

    不登高山,怎知天高;不临深溪,焉知地厚!站在坚实的土地上,做着生命中最真实的事情;像一棵挺拔的大树,认可自己的命运并敢于迎接属于这一方天空的风风雨雨。

  • 相关阅读:
    sublime text 4 vim 插件配置
    ssh-keygen 的使用
    distribution transaction solution
    bilibili 大数据 视频下载 you-get
    Deepin 20.2.1 安装 MS SQL 2019 容器版本
    【转】使用Linux下Docker部署MSSQL并加载主机目录下的数据库
    【转】You Can Now Use OneDrive in Linux Natively Thanks to Insync
    dotnet 诊断工具安装命令
    Linux 使用 xrandr 设置屏幕分辨率
    【转】CentOS 7.9 2009 ISO 官方原版镜像下载
  • 原文地址:https://www.cnblogs.com/net2012/p/2822980.html
Copyright © 2011-2022 走看看