SQL-07存储过程与触发器

SQL-07存储过程与触发器

ID:46948791

大小:344.81 KB

页数:20页

时间:2019-12-01

SQL-07存储过程与触发器_第1页
SQL-07存储过程与触发器_第2页
SQL-07存储过程与触发器_第3页
SQL-07存储过程与触发器_第4页
SQL-07存储过程与触发器_第5页
资源描述:

《SQL-07存储过程与触发器》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、第7章存储过程与触发器本章内容:存储过程触发器触发器类型创建触发器inserted和deleted临时表7.2触发器触发器是一种特殊类型的存储过程,当在指定的表中使用INSERT、DELETE或UPDATE语句修改表中的数据时,SQLServer自动执行触发器,以响应INSERT、UPDATE或DELETE语句。触发器与数据修改事件相关联,可分为三类:INSERT触发器:当向表中插入数据行时自动触发DELETE触发器:当从表中删除数据行时自动触发UPDATE触发器:当修改表中数据时自动触发触发器常用来实现复杂的数据完整性。7.2触发器例:XS和XS_KC之间

2、的引用完整性、学分和总学分之间的关系。学号姓名…总学分010001王林…40010002程明..30010003王玉民…15…………学号课程号成绩学分010001106803010001206904010002106703…………XSXS_KC7.2.1触发器的创建企业管理器创建触发器1、选择表,右击鼠标,选择“所有任务”,单击“管理触发器”。2、在“触发器属性”对话框中创建触发器。1、T-SQL创建触发器T-SQL语句创建触发器CREATETRIGGERtrigger_nameON{table

3、view}{{FOR

4、AFTER

5、INSTEADOF}{[IN

6、SERT][,][DELETE][,][UPDATE]}ASsql_statement[...n]说明:trigger_name:是触发器的名称。在数据库中必须唯一。Table

7、view:是在其上执行触发器的表(称为触发器表)或视图。AFTER:指定触发器只有在触发SQL语句中指定的所有操作都已成功执行后才激发。不能在视图上定义AFTER触发器。1、T-SQL创建触发器INSTEADOF:指定执行触发器而不是执行触发SQL语句,从而替代触发语句的操作。{[DELETE][,][INSERT][,][UPDATE]}:指定触发器的类型,即指定在表或视图上执行哪

8、些数据修改语句时将激活触发器。sql_statement:定义触发器被触发后,将执行的操作。例1:插入触发器CREATETRIGGERinsert_triggerONxs_kcforINSERTASSELECT‘insertintoxs_kc表'GO1、T-SQL创建触发器执行:insertxs_kcvalues('001101','106',80,3)可看出:SELECT‘insertintoxs_kc表’已经执行例2:插入触发器和更新触发器CREATETRIGGERupdate_triggerONxs_kcforINSERT,UPDATEASSELECT

9、'updateonxs_kc'GOinsertintoxs_kcvalues('010102','206',80,3)updatexs_kcset成绩=90where学号='010101'2、触发器中的两个特殊表执行触发器时,系统自动创建两个特殊的临时表:inserted表:表结构同触发器表,用于存储INSERT和UPDATE语句所影响的行的副本。deleted表:表结构同触发器表,用于存储DELETE和UPDATE语句所影响的行的副本。临时表中的数据由系统自动维护:执行INSERT时,新建行被同时添加到inserted表和触发器表中。执行DELETE时,行

10、从触发器表中删除,并传输到deleted表中。执行UPDATE时,从触发器表中删除旧行,并传输到deleted表中,新建行被添加到inserted表。只能在触发器中访问临时表中的数据,且不能修改其内容。3、应用举例例7.12创建一触发器,当向xs_kc表中插入一行数据时,检查插入数据中的学号是否在xs表中存在,课程号是否在kc表中存在:CREATETRIGGERcheck_trigONxs_kcFORINSERTASIFEXISTS(SELECT*FROMinsertedaWHEREa.学号NOTIN(SELECTb.学号FROMxsb)ora.课程号NOT

11、IN(SELECTc.课程号FROMkcc))BEGINRAISERROR('违背数据的一致性',16,1)ROLLBACKTRANSACTIONEND执行:insertxs_kcvalues('110100','106',80,2)修改上触发器,完成xs.总学分=xs.总学分+xs_kc.学分3、应用举例例:库存表存放当前仓库中现有产品的情况,出库表存放已经出库的产品的情况,现需出15台电视机。产品号产品名…库存数量01计算机…1002电视机…2003DVD…5…………产品号出库日期出库数量012006.2.210032006.2.155022006.3.

12、1015步骤:1、INSERT出库表VALUES(’

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。