数据库sqlserver-----触发器的插入,更新和删除

news2024/11/27 0:48:07

在学习触发器之前,先弄清DDL,DML,DQL,DCL的区别:

http://t.csdn.cn/Le3wA

触发器就是当执行某个事件的时候触发另一个事件的执行,根据事件的触发时间可分为

before和after

Before与After区别:before:(insert、update)可以对new进行修改,after不能对new进行修改。两者都不能修改old数据。

但是在sqlserver没有类似Oracle、Postgresql数据库的before功能,这里主要讲after

提要:创建两个表:buy 和detail

create table buy(
	buyid int not null identity(1,1),-----------表示buyid自增
	name varchar(20) not null,
	cost decimal(8,2)
)

create table detail(
	detailid int not null identity(1,1),
	buyid int not null,
	name varchar(20) not null,
	kind varchar(20) not null,
	oldcost decimal(8,2) null,
	newcost decimal(8,2) null,
)

关于自增函数和数据类型的补充可以看这篇,这里不细讲:

自增函数:

http://t.csdn.cn/u1VAX

数据类型:

http://t.csdn.cn/AVGMk

 两张虚拟表inserted,deleted

1.触发器的插入操作:

create trigger tri_buy_insert on buy
after insert
as
	insert into detail(buyid,name,kind,oldcost,newcost)
	select inserted.buyid,inserted.name,'新增',0.0,inserted.cost
	from inserted,buy
	where inserted.buyid=buy.buyid

在buy表中插入数据之前,两张表都为空

在buy表中插入一个数据之后:

insert into buy values('薯片',7.50)

不能写为

insert into buy values(1,'薯片',7.50)

否则会报:

仅当使用了列列表并且 IDENTITY INSERT 为 ON 时,才能为表'buy'中的标识列指定显式值。

第一个字段是自增的,插入时不需要赋值

插入后,则会看到:

 

2.触发器的更新操作:

1.

create trigger tri_buy_update on buy
after update
as 
	insert into detail(buyid,name,kind,oldcost,newcost)
	select inserted.buyid,inserted.name,'更新',deleted.cost,inserted.cost
	from inserted,deleted,buy
	where inserted.buyid=buy.buyid
	and deleted.buyid=buy.buyid

此时再更新一下buy表:

update buy set cost=6.7
where name='薯片'

得到效果如下:
 

触发器的删除操作:

instead of触发器是在insert、update、delete这些操作进行之前就被激活了,并且不再去执行原来的dml SQL操作,而是用触发器内部的SQL语句代替执行。

所以用了instead of的表做任何dml操作,都只会执行触发器内部的语句

   一个table或者view只能有一个instead of

   原始dml语句还是不会执行

这里用after和instead of执行效果是一样的

create trigger tri_buy_delete on buy
instead of delete
as
	insert into detail(buyid,name,kind,oldcost,newcost)
	select deleted.buyid,deleted.name,'删除',deleted.cost,0.00 
    from deleted,buy
    where deleted.buyid=buy.buyid

执行删除操作

delete from buy where name='薯片'

得到结果:


 

更新进阶:

2.

加入一张新表:calc,如下图:

	create table calc(
	maxcost decimal(8,2) null,
	mincost decimal(8,2) null,
	totalcost decimal(8,2) null,
	avgcost decimal(8,2) null
)

刚开始表为:

实现:

若calc为空,则插入新数据,若calc表不为空,则更新数据:

create trigger tri_buy_insert1 on buy
after insert
as
	if not exists(select * from calc)
	begin
		insert into calc(maxcost,mincost,totalcost,avgcost)
		select max(cost),min(cost),sum(cost),avg(cost)
		from cys_351_buy
	end
	else
	begin
		update calc set
		maxcost=(select max(cost) from buy),
		mincost=(select min(cost) from buy),
		totalcost=(select sum(cost) from buy),
		avgcost=(select avg(cost) from buy)
	end

第一次插入数据结果呈现:

 再次插入一个数据:

insert into buy values('冰淇淋',5.5)

 得到结果:

对于trigger before的替代方案:

http://t.csdn.cn/UB3gC

还在学习阶段,学习到新知识会不断补充

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

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

相关文章

数据结构学习记录——树习题—Tree Traversals Again(题目描述、输入输出示例、解题思路、解题方法C语言、解析)

目录 题目描述 输入示例 输出示例 解题思路 解题方法(C语言) 解析 题目描述 有序的二叉树遍历可以用堆栈以非递归的方式实现。 例如: 假设遍历一个节点数为6的二叉树(节点数据分别为1到6)时, 堆…

immersive-translate 安装,个人觉得一款超级好用的浏览器翻译插件

immersive-translate 安装,个人觉得一款超级好用的浏览器翻译插件 immersive-translate 是什么Github 地址主要特性立即安装使用 immersive-translate immersive-translate 是什么 Immersive Dual Web Page Translation Extension - 沉浸式双语网页翻译扩展。 Git…

MSP432学习笔记5——外部中断

所用单片机型号:MSP432P401r 今日继续我的MSP432电赛速通之路。 外部中断是个很有用的配置 STM32几乎每个I/O口都能配置复用为外部中断 但MSP432并不是这样。 我经过查阅数据手册发现支持中断的引脚为: P1^0~ P1^7 P3^0~ P3^7 P5^0~ P5^…

【Python习题】Python课程设计的作业分小组完成得分计算(实现代码)

目录 题目思路分析代码实现效果总结 主要内容是校设课程的习题和课外学习的一些习题。 欢迎关注 『Python习题』 系列,持续更新中 欢迎关注 『Python习题』 系列,持续更新中 题目 【题目描述】Python课程设计的作业分小组完成,规定小组成员1…

​Shodan新手入坑指南​

什么是 Shodan? 首先,Shodan 是一个搜索引擎,但它与 Google 这种搜索网址的搜索引擎不同,Shodan 是用来搜索网络空间中在线设备的,你可以通过 Shodan 搜索指定的设备,或者搜索特定类型的设备,其…

【C++】结构体 - 定义和使用,结构体数组,结构体指针,结构体嵌套结构体,结构体做函数参数,结构体const

文章目录 1. 定义和使用2. 结构体数组3. 结构体指针4. 结构体嵌套结构体5. 结构体做函数参数6. 结构体const 1. 定义和使用 结构体属于用户自定义的数据类型,允许用户存储不同的数据类型。 struct 结构体 {结构体成员列表}; 通过结构体创建变量的方法有三种&…

读数据压缩入门笔记02_二进制和熵

1. 十进制 1.1. 现代数学建立在十进制计数系统之上 2. 二进制 2.1. 二进制计数系统的工作原理与十进制计数系统一样,唯一的区别是前者的基数为2,而后者的基数为10 2.2. 数据压缩所做的就是尽可能减少表示特定数据集时所需的二进制位数量 2.3. 给定任…

WASender - Whatsapp server and bulk sender

WASender 是一个 whatsapp 营销平台,它使用 Laravel 和 Node Js 构建。WhatsApp 是世界上最受欢迎的消息应用程序之一,拥有超过 20 亿活跃用户。这使其成为企业接触潜在客户并与现有客户群互动的有吸引力的平台。WASender 客户可以创建多个设备来向他的目…

NLP基础知识(语法语义、LDA、N-gram、词嵌入)

文章目录 本节课大纲Hyper-simplified linguisticsTerm spotting handling negation, uncertaintyML to expand termspre-NN ML to identify entities and relationsLatent Dirichlet Allocation (LDA)Statistical Models of Language: Zipfs lawvector space embeddings base…

Office project 2016安装

哈喽,大家好。今天一起学习的是project 2016的安装,Microsoft Office project项目管理工具软件,凝集了许多成熟的项目管理现代理论和方法,可以帮助项目管理者实现时间、资源、成本计划、控制。有兴趣的小伙伴也可以来一起试试手。…

【WebLogic】WebLogic 14c服务器实例报BEA-001112的排查和解决

一、问题背景 WebLogic 14c配置了 MySQL 数据源(数据库使用的是MySQL的开源版本 - MariaDB),数据源其中一个 Target 为 WebLogic 应用域的一个受管服务器实例 - appServer1,并且为了增强 WebLogic JDBC Pool 里面的数据库连接的可…

NIO之FileChannel解读

目录 基本概述 打开 FileChannel 从 FileChannel 读取数据 向 FileChannel 写数据 关闭 FileChannel FileChannel 的 position 方法 FileChannel 的 size 方法 FileChannel 的 truncate 方法 FileChannel 的 force 方法 FileChannel 的 transferTo 和 transferFro…

华为OD机试真题B卷 Java 实现【寻找峰值】,附详细解题思路

一、题目描述 给定一个长度为n的数组nums,请你找到峰值并返回其索引。数组可能包含多个峰值,在这种情况下,返回任何一个所在位置即可。 1.峰值元素是指其值严格大于左右相邻值的元素。严格大于即不能有等于; 2.假设 nums[-1] n…

齿轮齿条平动模组的制作

1. 运动功能说明 齿轮齿条平动模组的主要运动方式为直流电机带动2个齿轮沿着齿条平行方向前进、后退。 2. 结构说明 本模组主要是由直流电机、齿轮、齿条、光轴、滑块、机架等组成。 3. 电子硬件 在这个示例中,我们采用了以下硬件,请大家参考&#xff1…

Fiddler抓不到包Fiddler chrome Edge无法抓包原因排查Fiddler死活抓不了包

一、问题描述 我这电脑上的Fiddler莫名其妙的死活就是无法抓包,换了几个版本的Fiddler都没有解决,这里参考了一些网上的教程,最终解决了,该文章算是比较详细的一篇介绍Fiddler无法抓包的教程。无法抓包主要由以下原因导致的&#…

1726_使用Python从dbc文件中提取simulink建模数据定义

全部学习汇总: GreyZhang/python_basic: My learning notes about python. (github.com) 使用dbc文件建模完成CAN通讯是一种比较高效的开发模式,不过在建模的过程中dbc文件中描述的数据需要自己去定义。使用文本编辑工具打开dbc文件可以看到&#xff0c…

中国生物科技公司【Advanced Biomed】申请纳斯达克IPO上市

来源:猛兽财经 作者:猛兽财经 猛兽财经获悉,总部位于台湾台南的生物科技公司【Advanced Biomed】近期已向美国证券交易委员会(SEC)提交招股书,申请在纳斯达克IPO上市,股票代码为(AD…

git的本地分支如何关联远程分支,比如github,gitlab,码云等

文章目录 1. 文章引言2. 本地分支如何关联远程分支2.1 远程有分支2.2 远程无分支 3. 总结 1. 文章引言 今天发布某版本的项目,准备创建个v0point1分支,后期如果修改该版本,直接在该分支上修改即可。 首先,使用git branch v0point…

SeaFormer实战:使用SeaFormer实现图像分类任务(一)

文章目录 摘要安装包安装timm安装mmcv安装 grad-cam 数据增强Cutout和MixupEMA项目结构计算mean和std生成数据集 摘要 论文翻译:https://blog.csdn.net/m0_47867638/article/details/130437649?spm1001.2014.3001.5501 官方源码:https://github.com/fu…

Vue2 创建 Vite 项目,新手教学

关于vite Vite是一种快速的现代化构建工具,可以显著提高Web应用程序的开发效率和性能。 以下是一些Vite的好处: 快速的冷启动:Vite使用原生ES模块解析器,在冷启动时会非常快速,不需要像Webpack一样构建整个应用程序。…