数据库练习题.docxVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 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

文档评论(0)

tianya189 + 关注
官方认证
文档贡献者

该用户很懒,什么也没介绍

认证主体阳新县融易互联网技术工作室
IP属地上海
统一社会信用代码/组织机构代码
92420222MA4ELHM75D

1亿VIP精品文档

相关文档