SQL SERVER触发器记录指定的几笔资料更新记录

1.目的

  为了记录数据库表中资料数据动态的变更,实时动态且方便调整记录的范围。

2.分析

     需求:记录UPDATE 修改的记录

  • if exists(select 1 from inserted) and exists(select 1 from deleted)          :修改
  • if (exists (select 1 from inserted) and not exists (select 1 from deleted)):新增
  • if (not exists (select 1 from inserted) and exists (select 1 from deleted)):删除

 3.实践

    1.创建一个LOG表结构,最好字段栏位跟原表A一致或大体接近

      *特别要注意!!!若是字符类型,长度一定要一致或者LOG表的字符长度 大于原表!!!

      否则更新后无法插入LOG记录!!!因为插入会报截断字符的错误!!!资料异常的情况下啊,误以为一直没有记录!!!

   2.建立触发器

  •    创建用 CREATE TRIGGER TRIG_A_TEST ....   即  创建用 CREATE TRIGGER 触发器名 ....  
  •    后续修改及调整用 ALTER  TRIGGER TRIG_A_TEST 即 后续修改及调整用 ALTER  TRIGGER 触发器名
  •    删除 DROP   TRIGGER TRIG_A_TEST 即 删除 DROP   TRIGGER TRIG_A_TEST  触发器名
    DROP   TRIGGER TRIG_A_TEST
  •    想要只需要部分TEST_NO的变更进行记录使用:  SELECT 1 FROM INSERTED WHERE TEST_NO  IN ('1','2','4')
  •     想要所有TEST_NO的变更进行记录使用:  SELECT 1 FROM INSERTED ,可以不用WHERE TEST_NO  IN ('1','2','4') 进行限制
CREATE TRIGGER TRIG_A_TEST  --创建触发器-- DROP TRIGGER TRIG_A_TEST --删除触发器
ON A_TEST
FOR UPDATE,DELETE
AS
BEGINSET NOCOUNT OFF; DECLARE @DATE AS DATETIME DECLARE @CNT AS INT SELECT @DATE = GETDATE()IF UPDATE([DEST]) OR UPDATE([SER_NO]) BEGINIF EXISTS(SELECT 1 FROM INSERTED WHERE TEST_NO  IN ('1','2','4')) AND EXISTS(SELECT 1 FROM DELETED WHERE TEST_NO  IN ('1','2','4'))--修改BEGINSELECT @CNT = COUNT(*) FROM INSERTED  WHERE TEST_NO  IN  ('1','2','4')IF @CNT > 1 BEGININSERT INTO A_TEST_LOG    SELECT  *,CONVERT(VARCHAR,@CNT),@DATE FROM INSERTED  WHERE TEST_NO  IN  ('1','2','4')ENDELSEBEGINIF ( (SELECT SER_NO FROM INSERTED WHERE TEST_NO  IN  ('1','2','4')) != 0  AND   (SELECT SER_NO FROM INSERTED WHERE TEST_NO  IN  ('1','2','4') ) != (SELECT SER_NO FROM DELETED WHERE TEST_NO  IN  ('1','2','4'))  )  OR (  (SELECT DEST FROM INSERTED WHERE TEST_NO  IN  ('1','2','4') ) != (SELECT DEST FROM DELETED WHERE TEST_NO  IN  ('1','2','4')) ) BEGININSERT INTO A_TEST_LOG    SELECT *,'0',@DATE FROM INSERTED  WHERE TEST_NO  IN ('1','2','4')END	     	        END	END	ENDEND

    3.查询触发器

  •  exec sp_helptext '触发器名字'
 exec sp_helptext 'TRIG_A_TEST'

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

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

相关文章

[Nacos]No spring.config.import property has been defined

在学习 Spring Cloud Alibaba ,Nacos组件,创建一个cloudalibaba-config-nacos-client,加载多配置集时遇到问题 配置了 bootstrap.yml 后启动项目报错: 是因为在springcloud 2020.0.2版本中把bootstrap的相关依赖从spring-cloud-s…

电脑文件msvcr120.dll丢失怎样修复?具体的msvcr120.dll修复方法分享

电脑文件msvcr120.dll丢失是一种比较常见的现象,只要是经常使用电脑的人,那么遇到msvcr120.dll丢失的次数就越多,今天主要来给大家聊一下msvcr120.dll丢失的各种解决方法。 一.电脑文件msvcr120.dll msvcr120.dl是由Microsoft提供的关键系统…

Qt飞机大战小游戏

Gitee地址 :plane-game: 基于Qt的飞机大战小游戏 GitHub地址: https://github.com/a-mo-xi-wei/plane-game

微信鸿蒙版本来了 我不允许你不会

前言: 各位同学大家好, 好久没有更新鸿蒙文章了 现在更新一个鸿蒙版本高仿微信版本 那么废话不多说 我们正式开始 作者:徐庆 团队:坚果派 公众号:“大前端之旅” 润开鸿生态技术专家,华为HDE,CSDN博客专家,CSDN超级个体,CSDN特邀嘉宾,InfoQ签约作者,OpenHarmony布…

2024牛客网高频精选Java面试八股文整理(附答案)

Java 面试 Java 作为编程语言中的 NO.1,选择入行做 IT 做编程开发的人,基本都把它作为首选语言,进大厂拿高薪也是大多数小伙伴们的梦想。以前 Java 岗位人才的空缺,而需求量又大,所以这种人才供不应求的现状,就是 Java 工程师的薪…

【CH32V305FBP6】USBD HS 描述符修改

文章目录 前言设备描述符配置描述符配置描述符CDC 描述符接口关联描述符接口描述符功能描述符端点描述符接口描述符端点描述符 HID 描述符接口描述符 练习:新增一个 HID 设备 前言 USB HS 复合设备,CDCHID 功能:串口、DAP、CAN-HID、RS485 …

健身小程序:智能化助力个人健身旅程

一、智能化功能的核心 健身小程序的智能化功能主要体现在以下几个方面: 智能健身计划推荐:小程序内置了先进的算法,能够根据用户的身体状况、健身目标和时间安排,智能推荐个性化的健身计划。这些计划不仅科学合理,而且…

零基础入门学用Arduino 第二部分(二)

重要的内容写在前面: 该系列是以up主太极创客的零基础入门学用Arduino教程为基础制作的学习笔记。个人把这个教程学完之后,整体感觉是很好的,如果有条件的可以先学习一些相关课程,学起来会更加轻松,相关课程有数字电路…

Pytorch环境配置的方法

Pytorch虚拟环境配置全流程 以安装pytorch1.9.1为例 1. 创建虚拟环境 安装Anaconda3,打开 PowerShell 创建虚拟环境并进入: conda create -n torch1.9.1 python3.8 conda activate torch1.9.1 conda create -n torch1.9.1 python3.8 conda activate to…

Flowable-决策表设计器

✨✨✨ 最好用的Flowable决策表设计器 ✨✨✨ 最好用的Flowable流程设计器 本文中内容和案例出自贺波老师的书《深入Activiti流程引擎:核心原理与高阶实战》,书中的介绍更全面、详细,推荐给大家。 深入Activiti流程引擎

3dsMax怎样让渲染效果更逼真出色?三套低中高参数设置

渲染是将精心构建的3D模型转化为逼真图像的关键步骤。但要获得令人惊叹的渲染效果,仅仅依赖默认设置是不够的。 实现在追求极致画面效果的同时,兼顾渲染速度和时间还需要进行一些调节设置,如何让渲染效果更加逼真? 一、全局照明与…

【递归、搜索与回溯】综合练习一

综合练习一 1.找出所有子集的异或总和再求和2.全排列 II3.电话号码的字母组合4.括号生成 点赞👍👍收藏🌟🌟关注💖💖 你的支持是对我最大的鼓励,我们一起努力吧!😃😃 1.找…

sku与spu的区别!!!

一个 SPU 可以有多个 SKU。

深度学习(六)——神经网络的基本骨架:nn.Module的使用

一、torch.nn简介 官网地址: torch.nn — PyTorch 2.0 documentation 1. torch.nn中的函数简介 Containers:神经网络的骨架 Convolution Layers:卷积层 Pooling layers:池化层 Padding Layers:Padding Non-linear …

Linux多线程编程中的同步与互斥

文章目录 一、线程同步与互斥1、理解线程同步2、互斥的概念3、小结 二、互斥锁(Mutex)1、互斥锁的定义和作用2、pthread库中的互斥锁3、互斥锁的实现原理4、示例代码演示互斥锁的基本用法 三、条件变量(Condition Variable)1、条件…

RK3566调试VI5301

VI5301是南京芯视界推出的一款直接飞行时间(dToF)传感器,与ST的VL53L0x兼容。 一、开发平台 系统:linux 4.19(buidroot) 二、驱动移植 解压厂家提供的驱动文件:VI5301_Linux_General_M40_V202,目录结构…

QML学习及实战

QML学习及实战(更多内容) 创建项目 3. 剩下的就是一路下一步即可 添加静态资源——图片 添加之后完成之后的路径 案列 || demo 可以参考的资料:https://github.com/gongjianbo/MyTestCode/blob/master/README.md 1. 文本省略号 Text {wi…

Python中关于电商商品数据的采集【taobao/JD/商品详情数据返回】

在Python中采集电商商品数据(如淘宝、京东等)通常涉及到网络爬虫(web scraping)或称为网络数据抓取(web data scraping)。由于电商平台通常会有反爬虫机制,因此直接抓取数据可能会遇到各种挑战&…

CV每日论文--2024.6.14

1、ICE-G: Image Conditional Editing of 3D Gaussian Splats 中文标题:ICE-G:3D 高斯斑点的图像条件编辑 简介:近年来,出现了许多技术来创建高质量的3D资产和场景。然而,当涉及到这些3D对象的编辑时,现有方法要么速度慢、要么牺牲质量,要么…

【ai】blender4.1 安装插件

开源软件,所以资料充足插件及配置 下载插件插件是python开发的 编辑中的偏好设置 点击选中 点击一键切换中文英文 切换主题 插件源码