SQL Serever学习14——存储过程和触发器
存储过程
在数据库中很多查询都是大同小异,编写他们费时费力,将他们保存起来,以后执行就很方便了,把SQL语句“封装”起来。
存储过程的概念
存储过程是一组SQL语句集,经过编译存储,可以”一次编译,多次执行“。除了第一次调用需要编译,后面都可以直接执行,执行速度更快,而不是普通SQL语句一样,每一次执行都要编译。
提供一种安全机制,如果某用户满意特定视图的使用权限,但是有使用存储过程的权限,通过执行存储过程,依旧可以获取存储过程中的表。
存储过程的优点
- 改善系统性能,一次编译,多次执行,而普通SQL是每一次都编译执行
- 安全机制
- 重用性,可以反复调用
- 共享性
- 减少网络流量,存储过程是服务器上编译好的T-sql代码,对一个可能需要几百行的T-sql操作,在客户端只需要通过一条执行语句完成,而不是发送几百行代码
存储过程分类
分为3类:
系统存储过程
通常以sp_开头,有sp_helpdb查看数据库名称和大小
所在位置
还有sp_helptext用于小时规则,默认值,触发器
sp_renamedb重命名数据库
sp_rename 重命名表,列,用户定义的类型
sp_helplogins看用户登录的数据
用户存储过程
用户编写的存储过程(主要是的的就是这个部分)
扩展存储过程
为扩展sqlserver提供的方法,可以动态的加载和执行动态链接库的函数,以xp_开头
存储过程的创建语句
CREATE PROC[EDURE] 存储过程名 [@参数名 参数类型 =默认值 ] OUTPUT WITH RECOMPILE FOR REPLICATION AS SQL语句组
说明:OUTPUT是输出参数,
RECOMPILE表示sqlserver不对存储过程计划进行高速缓存,每一次重新编译,
FOR REPLICATION表示存储过程只能在复制过程中使用,而且不和WITH RECOMPILE一起使用。
存储过程执行语法格式
EXEC[UTE] [@状态值=] 存储过程名 [@参数名=] 参数值
存储过程重新编译
sqlserver强制重新编译存储过程3种方法:
- 系统存储过程 ,EXEC sp_recompile 存储过程名
- 可以创建的时候使用WITH RECOMPILE
- 指定WITH RECOMPILE选项,EXEC 存储过程 WITH RECOMPILE
存储过程修改
就是把创建语句的CREATE 换成ALTER ,仅此而已。
ALTER PROC[EDURE] 存储过程名 [@参数名 参数类型 =默认值 ] OUTPUT WITH RECOMPILE FOR REPLICATION AS SQL语句组
存储过程删除
可以一次删除多个存储过程
DROP PROCEDURE PROC_3 , PROC_4
创建一个简单的存储过程
CREATE PROC 简单的存储过程
AS
BEGIN
SELECT 商品编号 ,商品名称,销售价
FROM 商品表
WHERE 商品名称='笔记本'
END
GO
存储过程中输入输出参数在AS之前,申明,局部变量在AS之后,申明。
创建带参数的存储过程
CREATE PROC 带参数的存储过程
@SPM VARCHAR(20) ='笔记本'
AS
BEGIN
DECLARE @JG SMALLMONEY
SELECT @JG=销售价
FROM 商品表
WHERE 商品名称=@SPM RETURN @JG
END
GO
使用带参数,有返回值的存储过程
DECLARE @MAXJG SMALLMONEY
EXEC @MAXJG=带参数的存储过程
SELECT @MAXJG AS 最高的实际销售价格
数据库的触发器
触发器的概念
触发器是特殊的存储过程,只不过它是在操作数据表(增删改)之前或者之后,自动执行的,不能铜鼓名称来调用。
优点
自动,操作表之后立即激活
实施更为复杂的数据约束
级联修改数据库中相关表,自动触发其他与之相关操作
跟踪变化,撤销和回滚
返回自定义错误信息(一般的约束是无法返回信息的)
可以调用更多的存储过程
分类
触发器分为2类:
DML
DDL
DML触发器
进行了增删改之后自动激活,有分为AFTER触发(操作后触发,执行优先级在约束检查之后),和INSTEAD OF 触发(不会执行增删改操作,而是执行INSTEAD OF指定操作,执行优先级在约束检查之前)。
DDL触发器
在执行CREATE, ALTER , GRANT , DENY , REVOKE, UPDATE STATISTICS语句触发。
触发器专用临时表
有2个触发器专用临时表INSERTED 和DELETED
表存在INSERT触发器(DDL触发器),插入数据,系统自动创建一个与表一样结构的INSERTED临时表,新的记录同时,添加到触发器表和INSERTED中,INSERTED保存的副本,方便用户查找当前插入数据。
表存在DELETE触发器,删除数据,系统自动创建一个DELETED临时表,用来保存被删除记录。
修改表,就是删除一条记录,然后插入一条记录,删除记录添加到DELETED表,新增记录添加到INSERTED表。
触发器的创建和触发
DML触发器
CREATE TRIGGER 触发器 ON 表名
FOR | AFTER | INSTEAD OF INSERT ,UPDATE , DELETE
AS SQL语句
DDL触发器
CREATE TRIGGER 触发器 ON ALL SERVER | DATABASE
FOR | AFTER 事件种类
AS SQL语句
触发器的修改
和创建类似,就是把CREATE 改为ALTER
触发器的删除
DROP TRIGGER 触发器, 触发器2
触发器的启用与禁用
禁用触发器
ALTER TABLE 表名 DISABLE TRIGGER 触发器名
DISABLE TRIGGER 触发器名
禁用数据库级别触发器
DISABLE TRIGGER 触发器名 ON DATABASE
启用触发器
ALTER TABLE 表名 ENABLE TRIGGER 触发器名
ENABLE TRIGGER 触发器 ON 表名
简单的触发器
USE 销售管理
GO
CREATE TRIGGER tr_insert_mj
ON 买家表 FOR INSERT --指定触发类型
AS
BEGIN
PRINT '有新买家插入到买家表'
END
GO
验证,插入一条数据
INSERT INTO 买家表
VALUES('M05','MARS',12232323,'J01')
GO
看消息,触发器运行了
创建一个DDL触发器,当删除数据库中的表时,就撤销该操作,并提示:禁止删除数据库表!
USE 销售管理
GO
CREATE TRIGGER tr_drop_dll
ON DATABASE
FOR DROP_TABLE
AS
BEGIN
ROLLBACK TRANSACTION
PRINT '禁止删除数据表!'
END
GO
验证一下,删除表
DROP TABLE 买家表
GO
看信息提示
禁用触发器
ALTER TABLE 买家表
DISABLE TRIGGER tr_insert_mj
或者
DISABLE TRIGGER tr_insert_mj ON 买家表
启用触发器
ALTER TABLE 买家表
ENABLE TRIGGER tr_insert_mj
或者
ENABLE TRIGGER tr_insert_mj ON 买家表
SQL Serever学习14——存储过程和触发器的更多相关文章
- 在论坛中出现的比较难的sql问题:14(存储过程问题 存储过程参数、存储过程内的参数)
原文:在论坛中出现的比较难的sql问题:14(存储过程问题 存储过程参数.存储过程内的参数) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决的 ...
- SQL Serever学习6——数据表
数据表 表的构成 数据库中的基本表由记录(行)和字段(列)构成,SQLServer2008每个表可以有1024个列,每个列可以有8060字节(不包括iamge,ntext,text类型). 记录(Re ...
- 遍历SQL SERVER中所有存储过程和触发器
如果需要查找某个存储过程或触发器中是否含有某段文本(比如:你想知道有哪些存储过程操作了某个表) 可以这么写 select name from sysobjects o, syscomments s w ...
- SQL Serever学习16——索引,触发器,数据库维护
sqlserver2014数据库应用技术 <清华大学出版社> 索引 这是一个很重要的概念,我们知道数据在计算机中其实是分页存储的,就像是单词存在字典中一样 数据库索引可以帮助我们快速定位数 ...
- SQL Serever学习9——基础查询语句
SQL语言概述 SQL是结构化查询语言(Structure Query Language),1974年提出,1979年被IBM实现,SQL语言已经成为关系型数据库的标准语言. 包括: DDL数据定义语 ...
- SQL Serever学习15——进阶
特别说明:在sqlserver2014中,不区分大小写,也就是说,SQL是大小写不敏感的 数据库模型3类: 层次模型 网状模型 关系模型 关系型数据库语言3种: DDL数据定义语言 CREATE(创建 ...
- SQL Serever学习4
SQL Server系统中数据库相关概念 在SQLServer数据库系统中分为2大类,系统数据库和用户数据库. SQLServer安装后系统会自动生成4个系统数据库,他们是Master,Model,M ...
- SQL Serever学习17——数据库的分析和设计
数据库的分析和设计 设计数据库确定一个合适的数据模型,满足3个要求: 符合用户需求,包含用户所需的所有数据 能被数据库管理系统实现,如sqlserver,oracle,db2 具有比较高质量,容易理解 ...
- SQL Serever学习13——数据库编程语言
编程基础 注释 注释命名来对一些语句进行说明,便于日后维护或者其他用户理解,注释不会执行. 单行注释 SELECT GETDATE() --查询当前日期 多行注释 /* 注释有助于 理解操作的内容 查 ...
随机推荐
- WPF自定义进度条
<!--进度条 4812--> <LinearGradientBrush x:Key="ProgressBarIndicatorAnimatedFill" Sta ...
- 论文研读之Spinnaker
论文:Using Paxos to Build a Scalable, Consistent, and Highly Available Datastore Motivation 可扩展性: 随着数据 ...
- ADV拍卖
#include <stdio.h> int ren,wuping; int qian[20]; int wu1[20],wu2[20],wu3[20]; int a[20],visit[ ...
- 【OCP新题库】052最新题库解析-第5题
5.Which two affect the time taken for instance recovery? A) size of redo logs B) size of UNDO tables ...
- 那些令人敬佩的刚学OI的大佬
我是萌新刚学OI,请问LCT怎么写常树最小啊 我是女生刚学OI,请问树链剖分哪里写挂了? 萌新求教,这棵SBT哪里有问题啊啊啊…… 刚学OI,请问可持久化非确定状态AC自动分块维护线段平衡仙人掌优化最 ...
- 删除标注关联仿dda命令DIMDISASSOCIATE
static void sk_ARXTestXDatamydimassoc(void) { // Add your code for command sk_ARXTestXData.mydimasso ...
- php防止网站被刷新
在实际应用中,总会遇到某些页面被恶意用户刷新.当你的系统在某些模块没有使用缓存的时候,频繁的刷新会导致数据库吃紧.下面附上一段代码,防止频繁的刷新造成的死机情况. 主要是从 session方面进行限制 ...
- webpack+vue中安装使用vue-layer弹窗插件
1.安装vue-layer插件 npm install vue-layer --save-dev 2.打包入口文件main.js中引入vue.vue-layer.并且将vue-layer添加到vue原 ...
- Vultr VPS建站攻略 – 一键安装宝塔面板架设LNMP/LAMP Web环境
我们选择VULTR VPS建站的还是比较多的,其主要原因在于商家的稳定,毕竟我们用来建站选择服务器价格考虑的不是主要的(当然VULTR价格也是比较便宜),最为主要的是因为VULTR商家比较稳定,而且多 ...
- 用 Hystrix 构建高可用服务架构
1 hystrix是什么 在分布式系统中,每个服务都可能会调用很多其他服务,被调用的那些服务就是依赖服务,有的时候某些依赖服务出现故障也是很正常的. Hystrix 可以让我们在分布式系统中对服务间的 ...