实验九 存储过程和触发器

题目

  1. 创建并执行一个无参数的存储过程proc_product1,通过该存储过程可以查询商品类别名称为"笔记本电脑"的商品的详细信息:包括商品编号、商品名称、品牌、库存量、单价和上架时间信息

2、创建并执行一个带输入参数的存储过程proc_product2,通过该存储过程可以根据输入参数供应商名称和包含关键字的商品名称进行商品具体信息的查询:包括商品编号、商品名称、品牌、库存量、单价、成本价、供应商名称、联系电话信息

3、创建并执行一个带输入参数和输出参数的存储过程proc_product3,通过该存储过程可以根据输入的会员用户名查询出该会员购买的商品信息:包括商品名称、购买数量和实付总金额信息

4、删除存储过程proc_product3

5、创建一个名为tri_insert1的DML触发器,该触发器的作用是:当向会员表member中添加一条记录时,如果新添加的会员编号已经存在于表中,则禁止插入该条记录,并提示该会员已经存在!。

6、创建一个名为tri_update1的DML触发器,该触发器的作用是:不允许修改订单表orders中的discount属性列的值,并给出提示语句"禁止修改orders表中的discount属性列的数据!"

7、创建一个名为tri_insert2的DML触发器,该触发器的作用是:当向会员表member新插入一条会员记录时,系统自动将部门表department中对应部门的属性列deptotal进行加1处理

8、创建一个名为tri_delete的DML触发器,该触发器的作用是:用删除会员表menmber中某条会员记录的时,系统自动在订单表orders中查询是否有该会员的订单记录,如果有,则同时删除该会员的所有订单记录

9、删除触发器tri_delete

步骤

  1. 创建并执行一个无参数的存储过程proc_product1,通过该存储过程可以查询商品类别名称为"笔记本电脑"的商品的详细信息:包括商品编号、商品名称、品牌、库存量、单价和上架时间信息

Create procedure proc_product1 as

select prono, proname, brand, stock, price, ontime from product

2.创建并执行一个带输入参数的存储过程proc_product2,通过该存储过程可以根据输入参数供应商名称和包含关键字的商品名称进行商品具体信息的查询:包括商品编号、商品名称、品牌、库存量、单价、成本价、供应商名称、联系电话信息

Create procedure proc_product2(@supname varchar(255), @keyword varchar(255))

as

select prono, proname, brand,

stock, price, cost, supname, telephone

from product

left join supplier

on supplier.supno = product.supno

where supname = @supname and proname like '%' + @keyword + '%'

3.创建并执行一个带输入参数和输出参数的存储过程proc_product3,通过该存储过程可以根据输入的会员用户名查询出该会员购买的商品信息:包括商品名称、购买数量和实付总金额信息

Create procedure proc_product3

@memname varchar(50)

as

select proname,qty,totalmoney

from member,product,orders

where member.memno=orders.memno and orders.prono=product.prono and memname = @memname

4、删除存储过程proc_product3

drop procedure proc_product3

5、创建一个名为tri_insert1的DML触发器,该触发器的作用是:当向会员表member中添加一条记录时,如果新添加的会员编号已经存在于表中,则禁止插入该条记录,并提示该会员已经存在!。

CREATE TRIGGER tri_insert1

on member

for insert

as

begin

declare @memno int;

select @memno = memno from inserted;

select * from member where memno = @memno;

if exists(select * from member where memno = @memno)

begin

rollback tran

print '不允许添加'

end

End

6、创建一个名为tri_update1的DML触发器,该触发器的作用是:不允许修改订单表orders中的discount属性列的值,并给出提示语句"禁止修改orders表中的discount属性列的数据!"

CREATE TRIGGER tri_update1

on orders

after update

as

if update(discount)

begin

rollback tran

print'禁止修改orders表中的discount属性列的数据!'

End

  1. 创建一个名为tri_insert2的DML触发器,该触发器的作用是:当向会员表member新插入一条会员记录时,系统自动将部门表department中对应部门的属性列deptotal进行加1处理

CREATE TRIGGER tri_insert2

on employee

after insert

as

begin

update department

set deptotal = deptotal+1

where depno = (select depno from inserted);

End

  1. 创建一个名为tri_delete的DML触发器,该触发器的作用是:用删除会员表menmber中某条会员记录的时,系统自动在订单表orders中查询是否有该会员的订单记录,如果有,则同时删除该会员的所有订单记录

CREATE TRIGGER tri_delete

on member

for delete

as

delete from orders

where memno=(select memno from deleted)

9、删除触发器tri_delete

drop trigger tri_delete

相关推荐
小O_好好学6 分钟前
CentOS 7文件系统
linux·运维·centos
哲伦贼稳妥30 分钟前
一天认识一个硬件之机房地板
运维·网络·经验分享·其他
john_hjy37 分钟前
11. 异步编程
运维·服务器·javascript
x晕x40 分钟前
Linux dlsym符号查找疑惑分析
linux·运维·服务器
活跃的煤矿打工人1 小时前
【星海saul随笔】Ubuntu基础知识
linux·运维·ubuntu
hgdlip2 小时前
如何快速切换电脑的ip地址
网络·tcp/ip·电脑
北京智和信通2 小时前
云平台和虚拟化智慧运维监控,全面提升故障感知与处置能力
运维·虚拟化·云平台·虚拟机监控
fasewer2 小时前
第五章 linux实战-挖矿 二
linux·运维·服务器
楚灵魈2 小时前
[Linux]从零开始的网站搭建教程
linux·运维·服务器
小小不董2 小时前
《Linux从小白到高手》理论篇:深入理解Linux的网络管理
linux·运维·服务器·数据库·php·dba