数据库SQL Server 9-10 章(存储过程与触发器)

本文涉及的产品
RDS SQL Server Serverless,2-4RCU 50GB 3个月
推荐场景:
云数据库 RDS SQL Server,基础系列 2核4GB
简介: 数据库SQL Server 9-10 章(存储过程与触发器)

思维导图

一、存储过程


1.存储过程

存储过程:是一组为了完成特定功能的SQL语句集,经编译后存储在数据库中。存储过程可包含程序流、逻辑以及对数据库的查询。它们可以接受参数、输出参数、返回单个或者多个结果集以及返回值。


为什么要使用存储过程?

1)存储过程与其他应用程序共享应用程序逻辑

2)具有安全性和所有权连接,以及可以附加到他们的证书

3)提供安全机制

4)允许模块化程序设计

5)可以减少网络通信流量

存储过程的种类

用户自定义存储过程

系统存储过程

扩展存储过程

创建存储过程


CREATE PROC 存储过程名称
参数
Varying=default
With
Recompile
As
Sql_statement[…n]

修改存储过程

ALTER PROCEDURE procedure_name
参数
VARYING=default
With

删除存储过程

DROP PROCEDUER

设计存储过程的规则

1)可以引用在同一存储过程中创建的对象,只要引用时已创建了该对象即可 ;

2)可以在存储过程内引用临时表 ;

3)如果执行的存储过程将调用另一个存储过程,则被=调用的存储过程可以访问由第一个存储过程创建的所有对象,包括临时表在内 ;

4)如果执行远程SQL实例进行更远的远程存储过程,则不但能回滚这些更改远程存储过程不参与事务处理 ;

5)存储过程中的参数的最大数目为2100 ;

6)存储过程中的局部变量的最大数目仅受可用内存的限制 ;

7)根据可用内存的不同,存储过程最大可达125mb。

二、触发器


触发器是一个在修改指定表中的数据时执行的存储过程。经常通过创建触发器来强制实现不同表中的逻辑相关数据的引用完整性或一致性。由于用户不能绕过触发器,所以可以用它来强制实施复杂的业务规则,以此确保数据的完整性。触发器主要是通过事件进行触发而被执行的,而存储过程可以通过存储过程名字而被直接调用。


为什么要使用触发器?

触发器自动执行,它们在表的数据作了任何修改(比如手工输入或者使用程序采集的操作)之后立即激活。

触发器可以通过数据库中的相关表进行层叠更改。这比直接把代码写在前台的做法更安全合理。

触发器可以强制限制,这些限制比用CKECK约束所定义的更复杂,与CHECK约束不同的是,触发器可以引用其他表中的列。


触发器种类

1)DDL触发器

DDL触发器当服务器或者数据库中发生数据定义语言(DDL事件时)将被调用。如果要执行以下操作,可以使用DDL触发器:

要防止对数据库架构进行某些更改;

希望数据库中发生某种情况以响应数据库架构中的更改

要记录数据库架构中的更改或者事件

2)DML触发器

DML触发器是当前数据库服务器中发生数据操作语言(DML)事件时要执行的操作,通常所说的DML触发器主要包括三种:INSERT触发器、UPDATE触发器、DELETE触发器。DML触发器可以查询其他表,还可以包含复杂的T-SQL语句。将触发器和触发它的语句作为可在触发器内回滚的单个事务对待。如果检测到错误,则整个事务自动回滚。


创建INSERT触发器

CREATE TRIGGER trigger_name
On+表或者视图
{  
     For\after\instead of
     Delete,insert,update   
As
Sql_statement
}

创建DELETE触发器

Create trigger t_deleteteacher
On 教师信息
For delete
As 
Select .. as .. from deleted
触发:
Delete from .. where ..

创建update触发器

create trigger t_update 
on 教师信息
for update 
as
if(update(姓名)or update(性别))
begin     
print'事务不能被处理,基础数据不能修改!'
    rollback transaction
end
else    
print'数据修改成功!

创建DDL触发器

Create trigger trigger_name
On  all server|detabase
With encryption(是否加密)
For |after{event_type}
As
Sql_statement

递归触发器

任何触发器都可以包含影响同一个表或另一个表的UPDATE、INSERT或DELETE语句。如果启用递归触发器选项,那么改变表中数据的触发器,通过递归执行就可以再次触发自己。在数据库创建时,默认情况下递归触发器选项是禁用的,但可以使用ALTER DATABASE语句来启用它。


相关实践学习
使用SQL语句管理索引
本次实验主要介绍如何在RDS-SQLServer数据库中,使用SQL语句管理索引。
SQL Server on Linux入门教程
SQL Server数据库一直只提供Windows下的版本。2016年微软宣布推出可运行在Linux系统下的SQL Server数据库,该版本目前还是早期预览版本。本课程主要介绍SQLServer On Linux的基本知识。 相关的阿里云产品:云数据库RDS SQL Server版 RDS SQL Server不仅拥有高可用架构和任意时间点的数据恢复功能,强力支撑各种企业应用,同时也包含了微软的License费用,减少额外支出。 了解产品详情: https://www.aliyun.com/product/rds/sqlserver
相关文章
|
3月前
|
存储 SQL 数据库
SQL Server存储过程的优缺点
【10月更文挑战第18天】SQL Server 存储过程具有提高性能、增强安全性、代码复用和易于维护等优点。它可以减少编译时间和网络传输开销,通过权限控制和参数验证提升安全性,支持代码共享和复用,并且便于维护和版本管理。然而,存储过程也存在可移植性差、开发和调试复杂、版本管理问题、性能调优困难和依赖数据库服务器等缺点。使用时需根据具体需求权衡利弊。
|
3月前
|
SQL 开发框架 .NET
ASP.NET连接SQL数据库:详细步骤与最佳实践指南ali01n.xinmi1009fan.com
随着Web开发技术的不断进步,ASP.NET已成为一种非常流行的Web应用程序开发框架。在ASP.NET项目中,我们经常需要与数据库进行交互,特别是SQL数据库。本文将详细介绍如何在ASP.NET项目中连接SQL数据库,并提供最佳实践指南以确保开发过程的稳定性和效率。一、准备工作在开始之前,请确保您
301 3
|
14天前
|
SQL Oracle 数据库
使用访问指导(SQL Access Advisor)优化数据库业务负载
本文介绍了Oracle的SQL访问指导(SQL Access Advisor)的应用场景及其使用方法。访问指导通过分析给定的工作负载,提供索引、物化视图和分区等方面的优化建议,帮助DBA提升数据库性能。具体步骤包括创建访问指导任务、创建工作负载、连接工作负载至访问指导、设置任务参数、运行访问指导、查看和应用优化建议。访问指导不仅针对单条SQL语句,还能综合考虑多条SQL语句的优化效果,为DBA提供全面的决策支持。
42 11
|
28天前
|
SQL 关系型数据库 MySQL
MySQL导入.sql文件后数据库乱码问题
本文分析了导入.sql文件后数据库备注出现乱码的原因,包括字符集不匹配、备注内容编码问题及MySQL版本或配置问题,并提供了详细的解决步骤,如检查和统一字符集设置、修改客户端连接方式、检查MySQL配置等,确保导入过程顺利。
|
27天前
|
SQL 监控 安全
SQL Servers审核提高数据库安全性
SQL Server审核是一种追踪和审查SQL Server上所有活动的机制,旨在检测潜在威胁和漏洞,监控服务器设置的更改。审核日志记录安全问题和数据泄露的详细信息,帮助管理员追踪数据库中的特定活动,确保数据安全和合规性。SQL Server审核分为服务器级和数据库级,涵盖登录、配置变更和数据操作等事件。审核工具如EventLog Analyzer提供实时监控和即时告警,帮助快速响应安全事件。
|
2月前
|
SQL 数据采集 监控
局域网监控电脑屏幕软件:PL/SQL 实现的数据库关联监控
在当今网络环境中,基于PL/SQL的局域网监控系统对于企业和机构的信息安全至关重要。该系统包括屏幕数据采集、数据处理与分析、数据库关联与存储三个核心模块,能够提供全面而准确的监控信息,帮助管理者有效监督局域网内的电脑使用情况。
39 2
|
2月前
|
SQL Java 数据库连接
canal-starter 监听解析 storeValue 不一样,同样的sql 一个在mybatis执行 一个在数据库操作,导致解析不出正确对象
canal-starter 监听解析 storeValue 不一样,同样的sql 一个在mybatis执行 一个在数据库操作,导致解析不出正确对象
|
3月前
|
SQL 关系型数据库 MySQL
Go语言项目高效对接SQL数据库:实践技巧与方法
在Go语言项目中,与SQL数据库进行对接是一项基础且重要的任务
100 11
|
3月前
|
存储 SQL 缓存
SQL Server存储过程的优缺点
【10月更文挑战第22天】存储过程具有代码复用性高、性能优化、增强数据安全性、提高可维护性和减少网络流量等优点,但也存在调试困难、移植性差、增加数据库服务器负载和版本控制复杂等缺点。
145 1
|
3月前
|
存储 SQL 数据库
Sql Server 存储过程怎么找 存储过程内容
Sql Server 存储过程怎么找 存储过程内容
167 1