- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
任务13.4
问题描述:对[OrderDetails]表创建一个名称为OrderDetailNotDiscontinued的触发器。检查尝试插入或修改的每条记录,如果插入或修改的记录其产品已被终止,则撤销插入或修改的所有记录。
解决方案:
USENorthwind;
CREATETRIGGEROrderDetailNotDiscontinuedON[OrderDetails]
FORINSERT,UPDATEAS
IFEXISTS(
SELECT*
FROMInsertediJOINProductsp
ONi.ProductID=p.ProductIDWHEREp.Discontinued=1
)BEGIN
PRINT(OrderItemisdiscontinued.TransactionFailed.);ROLLBACKTRAN;
END
分析与讨论:
当对[OrderDetails]表插入或修改记录时,就会自动执行OrderDetailNotDiscontinued触发器。首先,将插入的行插入OrderDetails表和inserted表中,然后激发触发器。
由于插入或修改的每条记录的副本存储在Inserted表中,我们可以使用Products表和
Inserted表连接查询。如果插入或修改的某个记录的产品已被终止(如果产品被终止,则Discontinued列的值为1),则以上代码中的SELECT连接查询存在行,EXISTS的返回值为TRUE,就会执行以上代码中的BEGIN…END代码块,向客户端输出信息,然后回滚(撤销)所有插入或修改的每条记录。
如果插入或修改的每条记录的产品都未终止,则以上代码中的连接查询不存在行,就不
会执BEGIN…END代码块,就会成功插入或修改每条记录。
对OrderDetailNotDiscontinued触发器进行测试,首先创建如下的newOrderDetails表:
CREATETABLE newOrderDetails (OrderID int NOTNULL,ProductID int NOTNULL,UnitPrice money NOTNULL,Quantity smallint NOTNULL,Discount real NOTNULL
)
然后在newOrderDetails表中插入四行。其中有两行的ProductID值指定的产品被终止。
OrderIDDiscountQuantityUnitPriceProductID表
OrderID
Discount
Quantity
UnitPrice
ProductID
10248
0
75
30
9
10248
0
75
60
1
10248
0
10
30
17
10248
0
20
30
8
最后,将newOrderDetails中的数据插入OrderDetails表中。代码如下:
INSERTOrderDetails
SELECT*FROMnewOrderDetails
ProductID为9和17的产品的Discontinued列的值为1,这些产品被终止,OrderDetailNotDiscontinued触发器回滚(撤销)以上插入操作。
OrderDetailNotDiscontinued触发器在拒绝或接受每个数据修改事务时将其作为一个整体。不过,不必简单地只因为某些数据修改不可接受而回滚所有的数据修改。在触发器中使用相关子查询可以强制触发器逐个检查所修改的行。请看以下任务的解决方案。
任务13.5
问题描述:对[OrderDetails]表创建一个名称为conditionalIandU的触发器,检查尝试插入或修改的每条记录,conditionalIandU触发器会逐行对插入或修改进行分析,然后删除产品已被终止的行。
解决方案:
CREATETRIGGERconditionalIandUON[OrderDetails]
AFTERINSERTAS
IFEXISTS(SELECT*FROMInsertediJOINProductspONi.ProductID=p.ProductIDWHEREp.Discontinued=1)
BEGIN
DELETE[OrderDetails]FROM[OrderDetails],insertedWHERE[OrderDetails].Productid=inserted.Product
您可能关注的文档
最近下载
- 精品解析:北京市和平街第一中学2024-2025学年八年级上学期期中语文试题(原卷版).docx VIP
- 建筑垃圾处理及清运方案.docx VIP
- (2024)高中历史新课程标准考试模拟测试题及答案.pdf VIP
- 辽宁省名校联盟2025年高三1月份联合考试 语文试卷(含答案详解).pdf
- 矿山安全生产标准化讲义.ppt VIP
- 辽宁省名校联盟2025年高三3月份联合考试 语文试卷(含答案解析).docx
- 18如何帮助学生学会恰当的消费.docx VIP
- 个人生涯发展报告.ppt VIP
- 2024-2025学年高一上学期期中考试动员主题班会(共24张ppt).pptx
- 2025年中国邮政集团工作人员招聘考试笔试试题(含答案).docx VIP
原创力文档


文档评论(0)