详细分析SQL Server触发器的基本知识

news2025/1/9 20:22:44

目录

  • 前言
  • 1. 基本知识
  • 2. Demo
  • 3. 查找特定表的存储过程

前言

原先写过一篇类似的,不过是基于Mysql:添加链接描述

对应Sql Server的补充知识点:详细配置SQL Server的链接服务器(图文操作Mysql数据库)

1. 基本知识

基本知识其实差不多,先从CRUD开始

触发器的类型:

  • DML触发器:在对表进行插入、更新或删除操作时触发
    AFTER触发器:在操作完成后执行
    INSTEAD OF触发器:代替操作执行,操作本身不会发生
  • DDL触发器:在对数据库对象进行创建、修改或删除时触发
  • LOGON触发器:在用户登录到数据库时触发

触发器的作用

  • 数据验证:在数据修改前或后执行额外的验证逻辑
  • 审计记录:记录数据的变更历史
  • 自动计算:基于表中的数据自动计算其他值

2. Demo

创建触发器:

CREATE TRIGGER trigger_name
ON table_name
[AFTER | INSTEAD OF] {INSERT | UPDATE | DELETE}
AS
BEGIN
    -- 触发器逻辑
END;

增加触发器:

CREATE TRIGGER trg_AfterInsert
ON Employees
AFTER INSERT
AS
BEGIN
    INSERT INTO AuditLog (Action, LogDate, EmployeeID)
    SELECT 'INSERT', GETDATE(), EmployeeID
    FROM inserted;
END;

更新触发器:

CREATE TRIGGER trg_InsteadOfUpdate
ON Employees
INSTEAD OF UPDATE
AS
BEGIN
    -- 执行自定义的更新逻辑
    UPDATE Employees
    SET Name = inserted.Name
    FROM inserted
    WHERE Employees.EmployeeID = inserted.EmployeeID;
END;

查看触发器:

SELECT * 
FROM sys.triggers 
WHERE parent_id = OBJECT_ID('table_name');

删除触发器:

DROP TRIGGER trigger_name;

3. 查找特定表的存储过程

  • 查询当前数据库中的所有存储过程
SELECT name 
FROM sys.procedures;

在这里插入图片描述

  • 通过表名查询触发器:

使用sys.sql_modules视图和OBJECT_DEFINITION函数

SELECT OBJECT_NAME(object_id) AS ProcedureName
FROM sys.sql_modules
WHERE OBJECT_DEFINITION(object_id) LIKE '%YourTableName%';

在这里插入图片描述

多加一个字段属性,可以给出详细的存储过程的定义

SELECT 
    OBJECT_NAME(m.object_id) AS ProcedureName,
    m.definition AS ProcedureDefinition
FROM 
    sys.sql_modules m
WHERE 
    OBJECT_DEFINITION(m.object_id) LIKE '%ags.GateReservationDetail%';

在这里插入图片描述

  • 通过触发器名称查询:
    如果有多个名称,都可在in后面进行添加补充
SELECT 
    OBJECT_NAME(m.object_id) AS ProcedureName,
    m.definition AS ProcedureDefinition
FROM 
    sys.sql_modules m
WHERE 
    OBJECT_NAME(m.object_id) IN ('View_JobOwner');

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2040684.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

JVM虚拟机(一)介绍、JVM内存模型、JAVA内存模型,堆区、虚拟机栈、本地方法栈、方法区、常量池

目录 学习JVM有什么用、为什么要学JVM? JVM是什么呢? 优点一:一次编写,到处运行。(Write Once, Run Anywhere,WORA) 优点二:自动内存管理,垃圾回收机制。 优点三&am…

IOS 03 纯代码封装自定义View控件

本节将通过纯代码进行封装自定义View控件,以常用的设置页的item为例,实现UI效果如下: 1、创建SettingView继承自UIView import UIKitclass SettingView: UIView {} 2、重写 init() 和 required init?(coder: NSCoder) 方法 纯代码创建Set…

仿RabbitMq实现消息队列正式篇(虚拟机篇)

TOC目录 虚拟机模块 要管理的数据 要管理的操作 消息管理模块 要管理的数据 消息信息 消息主体 消息的管理 管理方法 管理数据 管理操作 队列消息管理 交换机数据管理 要管理的数据 要管理的操作 代码展示 队列数据管理 要管理的数据 要管理的操作 代码展示…

PHP转Go系列 | ThinkPHP与Gin框架之打造基于WebSocket技术的消息推送中心

大家好,我是码农先森。 在早些年前客户端想要实时获取到最新消息,都是使用定时长轮询的方式,不断的从服务器上获取数据,这种粗暴的骚操作实属不雅。不过现如今我也还见有人还在一些场景下使用,比如在 PC 端扫描二维码…

浅谈JDK

JDK(Java Development Kit) JDK是Java开发工具包,是Java编程语言的核心软件开发工具。 JDK包含了一系列用于开发、编译和运行Java应用程序的工具和资源。其中包括: 1.Java编译器(javac):用于将Java源代码编译成字节…

MS8923/8923S低压、高精度、推挽输出比较器

MS8923/8923S 是一款差分输入、高速、低功耗比较器,具 有互补 TTL 输出。其传输延时在 10ns 左右,输入共模范围可以 到负轨。 MS8923/8923S 可以在线性区保持输出稳定特性,单电 源供电是 5.0V ,双电源供电是 5V 。 MS89…

【算法/学习】:记忆化搜索

✨ 落魄谷中寒风吹,春秋蝉鸣少年归 🌏 📃个人主页:island1314 🔥个人专栏:算法学习 ⛺️ 欢迎关注:👍点赞 &#x1f44…

数据结构——队列的讲解(超详细)

前言: 我们在之前刚讲述完对于栈的讲解,下面我们在讲另一个类似栈的数据结构——队列,它们都是线性表,但结构是大有不同,下面我们直接进入讲解! 目录 1.队列的概念和结构 1.1.队列的概念 1.2.队列的结构 2.…

基于Python的去哪儿网数据采集与分析可视化大屏设计与实现

摘要 本文旨在介绍如何利用Python进行去哪儿网景点数据的采集与分析。通过采集去哪儿网上的景点数据,我们可以获取大量的旅游相关信息,并基于这些数据进行深入分析和洞察,为旅游行业、市场营销策略以及用户个性化推荐等提供支持。 本文将使用…

MySQL(DQL)

一,SQL语言分类 (1)数据查询语言(DQL:Data Query Language)其语句,也称为 “数据检索语句”,用以从表中获得数据,确定数据怎样在应用程 序给出。关键字 SELECT 是 DQL&a…

Python打包命令汇总

1、pyinstaller打包 环境安装:pip install pyinstaller 网络不好可以通过 -i 指定安装源:pip install pyinstaller -i https://pypi.tuna.tsinghua.edu.cn/simple/安装完成后通过:pyinstaller --version 查看是否安装成功 打包单个脚本&…

操作系统笔记二

虚拟内存 把不常用的数据放到硬盘上去,常用的代码或者数据才加载到内存,来实现虚拟的大内存的感觉 覆盖技术 目标:在较小内存运行较大程序。 原理:把程序按自身逻辑结构划分若干功能上相对独立的程序模块。不回同时执行的模块共…

FreeRTOS学习笔记(一)—— 裸机和RTOS,Freertos移植(MDK),stm32cubeIDE使用Freertos

FreeRTOS学习笔记(一)—— 裸机和RTOS,Freertos移植(MDK),stm32cubeIDE使用Freertos 文章目录 FreeRTOS学习笔记(一)—— 裸机和RTOS,Freertos移植(MDK&#…

uniapp/vue个性化单选、复选组件

个性化单选和复选组件在网页设计中非常常见,它们不仅能够提升用户界面的美观度,还能改善用户体验。此组件是使用vue uniapp实现的个性化单选复选组件。设计完成后,点击生成源码即可。 拖动组件过设计区 每行显示数量 默认支持每行三个&#…

Maven-学习首篇

目录 Maven简介基本概念&特点Maven的安装与配置Maven基础概念及使用方法Maven的项目结构Maven的使用Maven的依赖管理Maven的生命周期和插件常见疑问Maven的插件机制是如何工作的?Maven的POM文件主要包含哪些内容?Maven的生命周期包括哪些阶段&#x…

【C++语言】list的构造函数与迭代器

1. list的介绍及使用 1.1 list的介绍 list的文档介绍 1. list是可以在常数范围内在任意位置进行插入和删除的序列式容器,并且该容器可以前后双向迭代。 2. list的底层是双向链表结构,双向链表中每个元素存储在互不相关的独立节点中,在节点…

C++中的IO流

目录 1.C语言的输入与输出 2.流是什么 3.CIO流 标准IO流 IO流的四个标志 C文件IO流 4.stringstream的简单介绍 1.C语言的输入与输出 C语言中我们用到的最频繁的输入输出方式就是scanf ()与printf()。 scanf(): 从标准输入设备(键 盘)读取数据,并将值存放在变…

钢铁百科:A572Gr60和SA572Gr60材质分析、A572Gr60和SA572Gr60简介

A572Gr60和SA572Gr60是两种常用的结构钢板,它们在材质、执行标准、化学成分、力学性能、交货状态、应用范围和常用规格方面有所不同。 材质: A572Gr60:属于美国材料与试验协会(ASTM)标准下的A572系列高性能结构钢&…

UIAbility组件基础(一)

一、概述 UIAbility组件是一种包含UI的应用组件,主要用于和用户交互。UIAbility组件是系统调度的基本单元,为应用提供绘制界面的窗口。一个应用可以包含一个或多个UIAbility组件。每一个UIAbility组件实例都会在最近任务列表中显示一个对应的任务。 U…

自研低代码海报制作平台学习分享计划

vue3组件库开发前面咱卷完了JuanTree组件,接下来一起来卷vue3低代码海报制作平台的基础组件实现。首先是拖拽基础组件的开发,整好把前面学习的知识点再运用进来。 文章目录 效果演示基本拖拽区域拖拽旋转其他效果待实现 录屏说明 看一步步实现的效果&…