全文预览已结束
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
一: 触发器是一种特殊的存储过程它不能被显式地调用而是在往表中插入记录更新记录或者删除记录时被自动地激活。所以触发器可以用来实现对表实施复杂的完整性约束。 二: SQL Server为每个触发器都创建了两个专用表:Inserted表和Deleted表。这两个表。 一: 触发器是一种特殊的存储过程它不能被显式地调用而是在往表中插入记录更新记录或者删除记录时被自动地激活。所以触发器可以用来实现对表实施复杂的完整性约束。 二: SQL Server为每个触发器都创建了两个专用表:Inserted表和Deleted表。这两个表由系统来维护它们存在于内存中而不是在数据库中。这两个表的结构总是与被该触发器作用的表的结构相同。触发器执行 完成后与该触发器相关的这两个表也被删除。 Deleted表存放由于执行Delete或Update语句而要从表中删除的所有行。 Inserted表存放由于执行Insert或Update语句而要向表中插入的所有行。 三:Instead of 和 After触发器 SQL Server2000提供了两种触发器:Instead of 和After 触发器。这两种触发器的差别在于他们被激活的同: Instead of触发器用于替代引起触发器执行的T-SQL语句。除表之外Instead of 触发器也可以用于视图用来扩展视图可以支持的更新操作。 After触发器在一个Insert,Update或Deleted语句之后执行进行约束检查等动作都在After触发器被激活之前发生。After触发器只能用于表。 一个表或视图的每一个修改动作(insert,update和delete)都可以有一个instead of 触发器一个表的每个修改动作都可以有多个After触发器。 四:触发器的执行过程 如果一个Insertupdate或者delete语句违反了约束那幺After触发器不会执行因为对约束的检查是在After触发器被激动之前发生的。所以After触发器不能超越约束。 Instead of 触发器可以取代激发它的操作来执行。它在Inserted表和Deleted表刚刚建立其它任何操作还没有发生时被执行。因为Instead of 触发器在约束之前执行所以它可以对约束进行一些预处理。 五:使用T-SQL语句来创建触发器 基本语句如下: create trigger trigger_name on table_name view_name for After Instead of insert, update,delete as sql_statement 六:删除触发器: 基本语句如下: drop trigger trigger_name 七:查看数据库中已有触发器: - 查看数据库已有触发器 use jxcSoftware go select * from sysobjects where xtype=TR - 查看单个触发器 exec sp_helptext 触发器名 八:修改触发器: 基本语句如下: alter trigger trigger_name on table_name view_name for After Instead of insert, update,delete as sql_statement 九:相关示例: 1:在Orders表中建立触发器当向Orders表中插入一条订单记录时检查goods表的货品状态status是否为1(正在整理)是则不能往Orders表加入该订单。 create trigger orderinsert on orders after insert as if (select status from goods,inserted where =inserted.goodsname)=1 begin print the goods is being processed print the order cannot be committed rollback transaction -回滚避免加入 end 2:在Orders表建立一个插入触发器在添加一条订单时减少Goods表相应的货品记录中的库存。 create trigger orderinsert1 on orders after insert as update goods set storage=storage-inserted.quantity from goods,inserted where =inserted.goodsname 3:在Goods表建立删除触发器实现Goods表和Orders表的级联删除。 create trigger goodsdelete on goods after delete as delete from orders where goodsname in (select name from deleted) 4:在Orders表建立一个更新触发器监视Orders表的订单日期(OrderDate)列使其不能手工修改. create trigger orderdateupdate on orders after update as if update(orderdate) begin raiserror( orderdate cannot be modified,10,1) rollback transaction end 5:在Orders表建立一个插入触发器保证向Orders表插入的货品名必须要在Goods表中一定存在。 create trigger orderinsert3 on orders after insert as if (select count(*) from goods,inserted where =inserted.goodsname)=0 begin print no entry in goods for this order rollback transaction end 6:Orders表建立一个插入触发器,保证向Orders表插入的货品信息要在Order表
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 《GB-T 37400.5-2019重型机械通 用技术条件 第5部分:有色金属铸件》专题研究报告
- 自行车装配工诚信水平考核试卷含答案
- 2024年大学三年级海洋生态工程专业《生态工程设计》期末考试测验卷及答案
- 化工单元操作工持续改进强化考核试卷含答案
- 印后制作员岗前技术突破考核试卷含答案
- 《GBT 20863.2-2016 起重机 分级 第 2 部分:流动式起重机》专题研究报告
- 尿素加工工测试验证考核试卷含答案
- 蓄电池充电工岗前生产安全技能考核试卷含答案
- 锅炉大件热处理工岗位设备安全技术规程
- 农业地质调查员安全生产基础知识测试考核试卷含答案
- 全南县2025年公开选调机关事业单位工作人员历年真题库及答案解析(夺冠)
- 2025年郑州水务集团有限公司招聘80人笔试模拟试卷带答案解析
- 创伤急救模拟教学的团队协作模拟演练
- 2024年厦门市住房和建设局及所属事业单位招聘辅助岗位人员笔试真题
- 2025年国有企业管理专员岗位招聘面试参考题库及参考答案
- 慢性心衰相关认知功能障碍管理方案
- 无纺布袋采购合同范本
- 2025年上海公务员考试(城市建设管理)历年参考题库含答案详解(5套)
- 生猪屠宰兽医卫生检验人员理论考试题库及答案
- 小区开放对道路通行的影响数学建模
- 降低护理文件书写缺陷率QC
评论
0/150
提交评论