SQLserver中的触发器和存储过程

在 SQL Server 中,触发器是一种特殊的存储过程,它在指定的数据库表上发生特定的数据修改事件时自动执行。触发器可以用于执行各种任务,如数据验证、数据审计、自动更新相关表等。

触发器的类型

SQL Server 支持以下几种类型的触发器:

  1. INSERT 触发器:在向表中插入新行时触发。

  2. UPDATE 触发器:在修改表中的现有行时触发。

  3. DELETE 触发器:在从表中删除行时触发。

  4. INSTEAD OF 触发器:在执行 UPDATE、DELETE 或 INSERT 操作之前触发,允许你自定义操作而不是执行默认操作。

触发器的创建

创建触发器的基本语法如下:

CREATE TRIGGER trigger_name
ON table_name
AFTER|INSTEAD OF {INSERT | UPDATE | DELETE}
AS
BEGIN-- 触发器的 SQL 代码
END

示例

假设我们有一个名为 Employees 的表,我们想要在每次插入新员工记录时自动记录这一操作到 AuditLog 表中。

  1. 创建触发器

CREATE TRIGGER trg_AfterInsertEmployee
ON Employees
AFTER INSERT
AS
BEGININSERT INTO AuditLog (Action, EmployeeID, ChangedDate)SELECT 'Insert', EmployeeID, GETDATE()FROM inserted
END

在这个例子中,trg_AfterInsertEmployee 是触发器的名称,它在 Employees 表上定义。当有新记录插入 Employees 表时,触发器会将操作记录到 AuditLog 表中。

  1. 使用 INSTEAD OF 触发器

如果你想要自定义 INSERT 操作,可以使用 INSTEAD OF 触发器。例如,假设我们想要在插入新员工之前验证数据:

CREATE TRIGGER trg_InsteadOfInsertEmployee
ON Employees
INSTEAD OF INSERT
AS
BEGINIF (SELECT COUNT(*) FROM inserted WHERE Age < 18) > 0BEGINRAISERROR ('Cannot insert employee under 18 years old.', 16, 1)ROLLBACK TRANSACTIONRETURNENDELSEBEGININSERT INTO Employees (EmployeeID, Name, Age)SELECT EmployeeID, Name, AgeFROM insertedEND
END

在这个例子中,如果尝试插入年龄小于 18 岁的员工,触发器将阻止插入并返回错误。

注意事项

  • 触发器可以影响数据库性能,特别是在高频率更新的表上。

  • 触发器中的错误可能导致数据不一致,因此在生产环境中使用触发器时需要谨慎。

  • 触发器可以嵌套,但嵌套触发器可能导致复杂的逻辑和性能问题,应尽量避免。

创建一个insert的触发器

CREATE TRIGGER TRIGGER_STUDENT_AFTERINSERT ON STUDENT AFTER INSERTAS DECLARE @STUID INT, @STUNAME NVARCHAR(50),@STUAGE INTSELECT @STUID=STUID, @STUNAME=STUNAME,@STUAGE=STUAGE FROM STUDENTPRINT CONVERT(VARCHAR,@STUID)+','+@STUNAME+','+ CONVERT(VARCHAR,@STUAGE)INSERT INTO STUDENT01(STUID,STUNAME,STUAGE) VALUES(@STUID,@STUNAME,@STUAGE)

SQLserver中存储过程

在 SQL Server 中,存储过程是一组为了完成特定功能的 SQL 语句集合,这些语句被保存在数据库中,可以通过一个调用语句来执行。存储过程可以接收参数、返回结果,并且可以进行复杂的逻辑处理。

存储过程的优点

  1. 性能优化:预编译的 SQL 语句可以提高执行效率。

  2. 安全性:通过存储过程,可以限制用户直接访问数据库表,只允许通过存储过程来操作数据,从而提高数据安全性。

  3. 重用性:可以重复使用存储过程,减少代码冗余。

  4. 减少网络流量:逻辑封装在服务器端,减少了客户端和服务器端之间的通信。

  5. 事务管理:可以在存储过程中方便地管理事务。

创建存储过程

创建存储过程的基本语法如下:

CREATE PROCEDURE ProcedureName@param1 DataType,@param2 DataType
AS
BEGIN-- SQL statements
END

示例

假设我们想要创建一个存储过程来插入新员工的信息:

CREATE PROCEDURE AddEmployee@EmployeeID INT,@EmployeeName NVARCHAR(100),@Department NVARCHAR(100)
AS
BEGININSERT INTO Employees (EmployeeID, Name, Department)VALUES (@EmployeeID, @EmployeeName, @Department)
END

调用存储过程

调用存储过程使用 EXECEXECUTE 语句:

EXEC AddEmployee @EmployeeID = 1, @EmployeeName = 'John Doe', @Department = 'Sales'

参数化存储过程

存储过程可以有输入参数、输出参数和返回值:

CREATE PROCEDURE GetEmployeeByID@EmployeeID INT,@EmployeeName NVARCHAR(100) OUTPUT
AS
BEGINSELECT @EmployeeName = Name FROM Employees WHERE EmployeeID = @EmployeeID
END

调用带有输出参数的存储过程:

DECLARE @Name NVARCHAR(100)
EXEC GetEmployeeByID @EmployeeID = 1, @EmployeeName = @Name OUTPUT
SELECT @Name AS EmployeeName

错误处理

存储过程中可以使用 TRY...CATCH 语句进行错误处理:

CREATE PROCEDURE ProcessData
AS
BEGINTRY-- 可能出错的 SQL 语句ENDCATCHBEGINSELECT ERROR_NUMBER() AS ErrorNumber,ERROR_MESSAGE() AS ErrorMessageEND
END

存储过程的修改和删除

  • 修改存储过程:使用 ALTER PROCEDURE 语句。

  • 删除存储过程:使用 DROP PROCEDURE 语句。

ALTER PROCEDURE ProcedureName
AS
BEGIN-- 新的 SQL 语句
END
​
DROP PROCEDURE ProcedureName

注意事项

  • 存储过程可以非常复杂,包含循环、条件语句等。

  • 存储过程可以调用其他存储过程。

  • 存储过程的权限可以精细控制,例如,可以限制谁可以执行特定的存储过程。

  • 存储过程的执行可以通过动态 SQL 来实现更高级的功能。

使用存储过程按日期生产编号

CREATE PROC PROCCREATENO  AS 
BEGIN 
DECLARE @NO VARCHAR(20),@LASTSTOCKNO VARCHAR(20) ,@STRTIMESTR VARCHAR(8)
SET @STRTIMESTR= CONVERT(VARCHAR(8),GETDATE(),112)
SELECT @LASTSTOCKNO =(SELECT TOP 1 STOCKNO FROM STOCK WHERE SUBSTRING(STOCKNO,1,8)=@STRTIMESTR ORDER BY STOCKNO DESC)
PRINT @LASTSTOCKNO
IF @LASTSTOCKNO IS NULL
BEGIN 
SET @NO= @STRTIMESTR+'00001'
END
ELSE 
BEGIN
DECLARE @LEN INT ,@LASTNO INT,@TEMPNO VARCHAR(5),@N INT
SET @LASTNO =CONVERT(INT,SUBSTRING(@LASTSTOCKNO,9,5))+1
SET @LEN=LEN(@LASTNO)
SET @TEMPNO=CONVERT(VARCHAR,@LASTNO)
SET @N=0;
WHILE(@N<5-@LEN)
BEGIN
SET @TEMPNO='0'+@TEMPNO
SET @N+=1
END
SET @NO=@STRTIMESTR+@TEMPNO
END
INSERT INTO STOCK(STOCKNO) VALUES(@NO)
END

使用EXEC PROCCREATENO执行结果

结果为

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

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

相关文章

如何使用ssm实现开放式教学评价管理系统+vue

TOC ssm121开放式教学评价管理系统vue 第1章 绪论 1.1 背景及意义 系统管理也都将通过计算机进行整体智能化操作&#xff0c;对于开放式教学评价管理系统所牵扯的管理及数据保存都是非常多的&#xff0c;例如个人中心、教师管理、学生管理、游客管理、评价信息管理、综合评…

XSS- - - DOM 破坏案例与靶场

目录 链接靶场&#xff1a; 第一关 Ma Spaghet 第二关 Jefff 第三关 Ugandan Knuckles 第四关 Ricardo Milos 第五关 Ah Thats Hawt 第六关 Ligma 第七关 Mafia 第八关 Ok, Boomer 链接靶场&#xff1a; XS…

在DDD中应用模式

深层模型和柔性设计并非唾手可得。要想取得进展&#xff0c;必须学习大量领域知识并进行充分的讨论&#xff0c;还需要经历大量的尝试和失败。但有时我们也能从中获得一些优势。一位经验丰富的开发人员在研究领域问题时&#xff0c;如果发现了他所熟悉的某种职责或某个关系网&a…

[数据集][目标检测]电力场景输电线杆塔塔架金属锈蚀腐蚀生锈检测数据集VOC+YOLO格式1344张1类别

数据集格式&#xff1a;Pascal VOC格式YOLO格式(不包含分割路径的txt文件&#xff0c;仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数)&#xff1a;1344 标注数量(xml文件个数)&#xff1a;1344 标注数量(txt文件个数)&#xff1a;1344 标注…

makefile编译

文章目录 一、g和gcc的区别二、Linux下静态库和动态库三、makefile文件如何去编写 一、g和gcc的区别 基本定义&#xff08;参考AI让生活更美好&#xff09; gcc&#xff08;GNU Compiler Collection&#xff09;是一个编译器集合&#xff0c;最初是为C语言设计的&#xff0c;但…

fl studio mobile2024最新官方版V4.6.8安卓版+iOS苹果版

fl studio mobile&#xff0c;一款非常好用的音乐制作软件。该软件具有丰富多样的音乐类型让大家选择&#xff0c;内置多个好用的编辑工具、渲染工具、特效工具等可以使用。用户可以自由使用软件中的任何道具&#xff0c;直接在手机上编曲&#xff0c;进行音乐创作&#xff0c;…

iOS工程:获取手机相册权限,iOS原生系统弹窗, Privacy隐私政策选择,如何添加系统弹出并修改描述文字

【iOS工程】获取手机相册权限&#xff0c;iOS原生系统弹窗, Privacy隐私政策选择&#xff0c;如何添加系统弹出并修改描述文字 设备/引擎&#xff1a;Mac&#xff08;11.6&#xff09;/Mac Mini 开发工具&#xff1a;Xcode&#xff08;15.0.1&#xff09; 开发需求&#xff…

【Gaussian splatting系列学习】(三)

3DGS系列&#xff08;一&#xff09; 3DGS系列&#xff08;二&#xff09; 3DGS系列&#xff08;三&#xff09; 3D高斯球的颜色 基函数&#xff1a; 任何一个周期性函数可以分解为正弦和余弦的线性组合 球谐函数&#xff1a; 任何一个球面坐标的函数可以用多个球谐函数来近…

游戏引擎详解——图片

图片 图片的格式 图片文件格式pngjpg 纹理压缩格式ETC1/2PVRTCASTC 图片的属性 图片属性解释分辨率宽高像素值&#xff08;pt&#xff09;&#xff0c;如&#xff1a;1024*1024位深度用来存储像素颜色的值&#xff0c;如RGBA8888&#xff0c;红黄蓝透明度4个维度每个8bit&…

CentOS Docker搭建Mysql5.7集群

MySQL Replication MySQL提供了Replication功能&#xff0c;可以实现将一个数据库的数据同步到多台其他数据库。前者通常称之为主库&#xff08;master&#xff09;&#xff0c;后者则被称从库&#xff08;slave&#xff09;。MySQL复制过程采用异步方式&#xff0c;但延时非常…

初始redis:Zset有序集合

Set作为集合&#xff0c;有两个特点&#xff1a;唯一且无序。 Zset是有序集合&#xff0c;在保证唯一的情况下&#xff0c;是根据什么来排序的呢&#xff1f;排序的规则是什么&#xff1f; Zset中的member引入了一个属性&#xff0c;分数&#xff08;score&#xff09;&#…

立式报工台助力MES系统打造智能硬件解决方案

信息化与自动化的深度结合&#xff0c;使得企业在生产效率、质量控制以及资源管理等方面得以大幅提升。制造执行系统MES作为连接企业管理层与生产现场的重要桥梁&#xff0c;正在愈发得到重视。为了进一步强化MES系统的功能与应用&#xff0c;立式报工台作为一种新兴的智能硬件…

适用于 Windows 10 的最佳数据恢复免费软件是什么?

有没有适用于 Windows 10 的真正数据恢复免费软件&#xff1f;这篇文章将讨论这个话题&#xff0c;并分享什么是适用于 Windows 10/11/8.1/8/7/Vista/XP 的最佳数据恢复工具。 有没有适用于 Windows 10 的真正免费的数据恢复软件&#xff1f; 丢失重要数据&#xff0c;无论是由…

RISC-V vector(1) --- vector的引入与register说明

Vector相较于SIMD的优势 这两种实现方案&#xff0c;都是为了实现数据级并行性&#xff08;存在大量的数据可供程序同时计算&#xff09;&#xff1b; SIMD&#xff08;Single Instruction Multiple Data&#xff09; SIMD是将数据宽度和操作类型&#xff0c;都放在了指令中&a…

一道xss题目--intigriti-0422-XSS-Challenge-Write-up

目录 进入挑战 js代码 代码分析 构造payload ​编辑 结果 进入挑战 Intigriti April Challenge题目地址 打开题目后&#xff0c;找到对应页面的js代码&#xff0c;寻找一下我们用户可控的点 js代码 <!DOCTYPE html> <html lang"en"><head> …

[GKCTF 2021]excel 骚操作1

使用010editor打开发现zip头&#xff0c;改后缀名xlsx为zip&#xff0c;解压&#xff0c;在D:\python\flag (1)\xl\worksheets目录下有个sheet1.xml就是ecxel的sheet1的主要样式style 看到很多c r"B2" s"1&#xff0c;只是单元格数据不同而已 &#xff0c;还有的…

Awesome-LLMs-for-Video-Understanding - 基于大型语言模型的视频理解研究

Awesome-LLMs-for-Video-Understanding 是 基于大型语言模型的视频理解研究 github : https://github.com/yunlong10/Awesome-LLMs-for-Video-Understandingpaper&#xff1a;Video Understanding with Large Language Models: A Survey https://arxiv.org/pdf/2312.17432 视频…

C++20中的约束与概念

类模板、函数模板和非模板函数(通常是类模板的成员)可能与约束(constraint)相关联&#xff0c;该约束指定对模板参数的要求(requirements)&#xff0c;可用于选择最合适的函数重载和模板特化。约束是使用模板时需要通过模板参数满足的条件或要求。这些要求的命名集合称为概念(c…

Hadoop 分布式集群搭建

HDFS分布式集群搭建 一、部署规划1.1 进程规划1.2 软件规划1.3 用户规划1.4 目录规划 二、 搭建HDFS 分布式集群2.1 HDFS 集群配置2.1.1 下载安装 Hadoop2.1.2 修改 hadoop-env.sh 配置文件2.1.3 修改 core-site.xml 配置文件2.1.4 修改 hdfs-site.xml 配置文件2.1.5 修改 slav…

程序员:全栈的痛你不知道

上周一个同事直接对我开喷&#xff0c;骂我无能&#xff0c;说&#xff1a;“你怎么一个人就搞不定所有系统呢&#xff1f;”&#xff0c;我半支烟纵横IT江湖14余年&#xff0c;还是第一次被人这么嫌弃。 事情缘由 某公司的业务线特别多&#xff0c;有个业务线前后端项目共计…