数据库系统存储过程和触发器.ppt_第1页
数据库系统存储过程和触发器.ppt_第2页
数据库系统存储过程和触发器.ppt_第3页
数据库系统存储过程和触发器.ppt_第4页
数据库系统存储过程和触发器.ppt_第5页
免费预览已结束,剩余37页可下载查看

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

第14讲存储过程和触发器,一、存储过程1存储过程概述2存储过程的使用和管理二、使用触发器1触发器概述2触发器的使用和管理3使用存储过程维护数据完整性,练习写出SELECT语句,1从titles表的title_id,type,advance列中查询所有的advance不大于¥5500的business类型的书.2从titles表查询出版日期(pubdate)在1/1/199112/31/1991之间的书号(title_id)和出版日期(pubdate).,答案,1selecttitle_id,type,advancefromtitleswhereadvance1BEGINRAISERROR(一次只能删除一个,16,1)ROLLBACKTRANSACTIONEND,下例创建了一个简单的触发器.USENorthwindIFEXISTS(SELECTnameFROMsysobjectsWHEREname=tr_product_updateANDtype=TR)DROPTRIGGERtr_product_updateGOUSENorthwind,GOCREATETRIGGERtr_product_updateONproductsAFTERUPDATEASDECLAREmsgvarchar(100)SELECTmsg=str(rowcount)+“employeesupdatedbythisstatement”PRINTmsgRETURNGO它返回UPDATE操作所修改的行数.,通常存储过程和触发器可以用来维护数据库引用的行动完整性,也就是在与外键值相应的主键发生改变以后规范对外键可能执行的操作,约束外键值的变化.用户应该记得SQLServer提供的外键约束的特点.当存在外键引用时,用户不能删除或修改被引用的主键值或UNIQUE列的值.使用存储过程可以实现受外键约束限制的主键或UNIQUE列的删除和修改.一般用级联操作.,3使用存储过程维护数据完整性,当使用存储过程作级联修改时,可执行步骤:以新的主键值或UNIQUE列值向主表插入新的数据行,重复现存行的所有其他列的值.将依赖表中的外键值改为新值.删除主表中的旧数据行.当使用存储过程作级联删除时,可执行步骤:删除外键所在的行,或将外键修改为默认值或NULL.删除主表中的行.使用存储过程来维护数据的完整性,并不是要替代原有的外键约束.只是外键约束的补充.,下例建立了一个存储过程实现级联删除.USEpubsGOCREATEPROCdelete_titletitle_idtidASBEGINDELETEsalesWHEREtitle_id=title_idDELETEtitlesWHEREtitle_id=title_idENDGO,练习题建立一个存储过程级联删除数据库pubs的表titles和titleauthor,当

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论