Sqlserver 学习笔记

by:授客 QQ1033553122

-----------------------接Part 6-------------------

29 存储过程和触发器

存储过程由一组预先编辑好的SQL语句组成。将其放在服务器上。由用户通过指定存储过程的名称来执行。

触发器是一种特殊类型的存储过程,它不是由用户直接调用的,而是当用户对数据进行操作(包括数据的INSERT ,UPDATE,DELETE操作)时自动执行。

29.1创建、执行、删除简单的存储过程。

CREATE PROCEDURE 存储过程名

[@parameter data_type][= default][output][,…..]

AS

sql语句

29.2执行存储过程

对存储在服务器上的存储过程,可以使用exectue命令或者其名称执行

29.3查看存储过程

对用户建立存储过程,可以使用对象资源管理器或系统存储过程查看该存储过程的定义。

1, 使用对象资源管理器查看存储过程,在“对象资源管理器”窗口中,展开“数据库”结点,选择相应的数据库,展开“可编程性”,“存储过程”结点。

2, 使用系统存储过程查看存储过程,可以使用SP_HELPTEXT  SP_DEPENDS SP_HELP

29.4删除存储过程

可以利用资源管理器或者drop proc 语句将其删除

示例

--存储过程

CREATE PROCEDURE pro

AS

SELECT 学生.学号, 学生.姓名, 班级.班级名称, 专业.专业名称, 系部.系部名称

FROM 学生

JOIN 班级 ON 学生.班级代码=班级.班级代码

JOIN 专业 ON 班级.专业代码=专业.专业代码

JOIN 系部 ON 班级.系部代码=系部.系部代码

--上述语句的执行后,我们可以在[可编程性\存储过程]看到一个名为dbo.pro的存储过程

EXEC pro

--创建带参数的一个存储过程

CREATE PROC pro1

@sex VARCHAR(10),--注意这里有逗号

@id VARCHAR(10)

AS

SELECT 学生.学号, 学生.姓名, 班级.班级名称, 专业.专业名称, 系部.系部名称

FROM 学生

JOIN 班级 ON 学生.班级代码 = 班级.班级代码 AND 学生.性别 = @sex

JOIN 专业 ON 班级.专业代码 = 专业.专业代码

JOIN 系部 ON 班级.系部代码 = 系部.系部代码 AND 系部.系部代码 = @id

--执行存储过程

EXEC pro1 '男', '1'

--带输出参数的存储过程

CREATE PROC pro2

@setName VARCHAR(10),

@getNum VARCHAR(10) OUTPUT

AS

SELECT @getNum = 学号 FROM 学生 WHERE 姓名= @setName

--执行

----该语句的执行,看不到结果,但是如果用.net等编程语言调用时则会看到效果

EXEC pro2 '林姐','1'

--查看存储过程

EXEC SP_HELPTEXT pro1

EXEC
SP_DEPENDS pro1

EXEC
SP_HELP
pro1

--删除存储过程

DROP
PROC pro1

29.5触发器

触发器的优点:

1触发器自动执行,在对表中的数据做了任何修改之后立即被激活

2触发器能够对数据库中的相关表实现级联更改。

29.6临时表

INSERTED表和DELETED表用于存放对表中数据行的修改信息。他们是触发器执行时自动创建的。当触发器工作完成,他们也被删除。他们只是只读表,不能向他们写入内容。

INSERTED表:用来存储INSERT和UPDATE语句所影响的行的副本。

意思就是在INSERTED表中临时保存了被插入或被更新后的记录行。

在执行INSERT或UPDATE语句时,新加行被同时添加到INSERTED表和触发器表中。

DELETED表:用来存储DELETE和UPDATE语句所影响的行的副本。

意思是在DELETED表中临时保存了被删除或被更新前的记录行。在执行DELETE或UPDATE语句时,行从触发器表中删除,并传到DELETED表中。所以可以从deleted表中检查删除的数据行是否能删除。

所以当表中某条记录的某项值发生变化时,变化前的值已经通过系统自动创建的临时表DELETED表和INSERTED表保存了被删除行或插入的记录行的副本。我么可以从这两个表中查询出变化前的值并赋给变量。

29.7使用sql创建触发器

格式:

CREATE
TRIGGER trigger_name

ON {TABLE | view}

FOR {[INSERT],[DELETE],[UPDATE]}

AS

sql
语句

查看触发器信息

EXEC
sp_helptrigger

表名

删除触发器

DROP TRIGGER
触发器名称

示例

USE
student --在数据库student下的操作。。

GO---这个词不能少

--创建触发器

CREATE
TRIGGER tri_insert

ON
std_TABLE ---指定目标表

FOR
INSERT ---触发器类型

AS--别忘了这个

DECLARE
@a CHAR(20), @name
CHAR(20), @major
CHAR(20)

--从临时表INSERTED中获取数据,数据保存在定义的变量中

--INSERTED保存着被插入或更新后的数据

SELECT
@a =
学号,

@name =
姓名,

@major =
专业方向
FROM
INSERTED

--删除时的对应操作,把获取的数据插入另一表中

INSERT
INTO std_table2(学号,

名称,

专业方向)

VALUES(@a,
@name, @major)

--执行上述语句后,我们可以在触发器 结点下看到一个tri_insert

--测试

SELECT
* FROM std_table

--SELECT * FROM std_table2--此时出错,std_table2没有建立

--删除触发器

DROP
TRIGGER tri_insert

--重新创建

USE
student --在数据库student下的操作。。

GO---这个词不能少

--上述语句的执行--选定数据库,和试图界面下手动选定一个样

--创建触发器

CREATE
TRIGGER tri_insert

ON
std_TABLE ---指定目标表

FOR
INSERT---触发器类型

AS--别忘了这个

DECLARE
@a CHAR(20), @name
CHAR(20), @major
VARCHAR(20)--注意这边貌似只能这样写,多个变量一起定义

--从临时表INSERTED中获取数据,数据保存在定义的变量中

--INSERTED保存着被插入或更新后的数据

SELECT
@a =
学号,

@name =
姓名,

@major =
专业方向
FROM
INSERTED

--删除时的对应操作,把获取的数据插入另一表中

INSERT
INTO std_table1(学号,

姓名,

专业方向)

VALUES(@a,
@name, @major)

--测试

SELECT
* FROM std_table

SELECT
* FROM std_table1

--查看触发器的信息

exec
sp_helptrigger
std_table

SQLServer 学习笔记之超详细基础SQL语句 Part 7的更多相关文章

  1. SQLServer 学习笔记之超详细基础SQL语句 Part 3

    Sqlserver 学习笔记 by:授客 QQ:1033553122 -----------------------接Part 2------------------- 13. 使用compute对查 ...

  2. SQLServer 学习笔记之超详细基础SQL语句 Part 12(The End)

    Sqlserver 学习笔记 by:授客 QQ:1033553122 -----------------------接Part 11------------------- 现在,我们希望从 " ...

  3. SQLServer 学习笔记之超详细基础SQL语句 Part 11

    Sqlserver 学习笔记 by:授客 QQ:1033553122 -----------------------接Part 10------------------- DECLARE @myavg ...

  4. SQLServer 学习笔记之超详细基础SQL语句 Part 10

    Sqlserver 学习笔记 by:授客 QQ:1033553122 -----------------------接Part 9------------------- 删除约束的语法 ALTER T ...

  5. SQLServer 学习笔记之超详细基础SQL语句 Part 9

    Sqlserver 学习笔记 by:授客 QQ:1033553122 -----------------------接Part 8------------------- 3 范式的概念 第一范式的目标 ...

  6. SQLServer 学习笔记之超详细基础SQL语句 Part 8

    Sqlserver 学习笔记 by:授客 QQ:1033553122 -----------------------接Part 7------------------- --触发器str_trigge ...

  7. SQLServer 学习笔记之超详细基础SQL语句 Part 6

    Sqlserver 学习笔记 by:授客 QQ:1033553122 -----------------------接Part 5------------------- 28 聚合函数 --求平均分 ...

  8. SQLServer 学习笔记之超详细基础SQL语句 Part 5

    Sqlserver 学习笔记 by:授客 QQ:1033553122 -----------------------接Part 4------------------- 21使用默认 默认(也称默认值 ...

  9. SQLServer 学习笔记之超详细基础SQL语句 Part 4

    Sqlserver 学习笔记 by:授客 QQ:1033553122 -----------------------接Part 3------------------- 17 带比较运算符的嵌套查询 ...

随机推荐

  1. Jenkins配置项目

    前提:服务器上部署了jenkins+Tomcat,并且安装了所需插件 1.新建项目 -- 项目配置 2.配置git地址 出现上述错误是因为该git地址,在jenkins服务器上无权限访问.在git上开 ...

  2. copy代码的时候,如何去掉代码前边的编号

    从网页上拷贝下来的代码前面总有编号,如何去掉! 1.使用正则表达式:在editorplus(notepad++)里按ctrl+h,弹出框里勾选上“正则表达式(regular expression)”, ...

  3. (转)python通过paramiko实现,ssh功能

    python通过paramiko实现,ssh功能 1 import paramiko 2 3 ssh =paramiko.SSHClient()#创建一个SSH连接对象 4 ssh.set_missi ...

  4. [转]让程序不触发 Vista/Win7下应用程序兼容性助手弹出 .

    原文地址 http://blog.csdn.net/maxuhuiabc/article/details/6081874 在Vista/Win7下 运行一个 exe 应用程序后,系统经常弹出 兼容性助 ...

  5. Spring AOP介绍及源码分析

    转自:http://www.uml.org.cn/j2ee/201301102.asp 软件开发经历了从汇编语言到高级语言和从过程化编程到面向对象编程:前者是为了提高开发效率,而后者则使用了归纳法,把 ...

  6. 第一次项目上Linux服务器(五:CentOS7下Mysql数据库的安装与配置(转))

    好像在CentOS 7系统中,默认安装的mysql是它的分支mariadb.所以不能像CentOS-6.3那样安装,如下: [root@izwz ~]# yum -y install mysql my ...

  7. 分布式理论(二)——Base 理论

    前言 在前文 分布式理论(一) -- CAP 定理 中,我们说,CAP 不可能同时满足,而分区容错是对于分布式系统而言,是必须的.最后,我们说,如果系统能够同时实现 CAP 是再好不过的了,所以出现了 ...

  8. (译) 在AngularJS中使用的表单验证功能【转】

    验证功能是AngularJS里面最酷炫的功能之一,它可以让你写出一个具有良好用户体验的Web应用. 在AngularJS中,有许多用于验证的指令.我们将先学习几个最流行的内置指令,然后再创建一个自定义 ...

  9. windows下使用python操作redis(Visual Studio Code)

    1.编辑工具: Visual Studio Code(windows环境) 2.redis服务器:这里用了远程连接,需要配置redis.conf. (1)注释 #bind 127.0.0.1 (2)设 ...

  10. Vue之组件使用(二)

    补充一下:之前没提到,这里是一个父子组件通信的方法 如果想要使同一个组件实现不同的效果,那么可以这样做. 把需要封装的组件模板写在template中 <template id="cou ...