实验九 存储过程和触发器

题目

  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

相关推荐
Ha_To23 分钟前
2025.12.22 OSPF多区域原理与配置方法
网络
QT 小鲜肉34 分钟前
【Linux命令大全】001.文件管理之git命令(实操篇)
linux·服务器·笔记·git·elasticsearch
半夏知半秋37 分钟前
docker常用指令整理
运维·笔记·后端·学习·docker·容器
sishen41991 小时前
嵌入式Linux没有学习方向怎么办,嵌入式Linux怎么学
linux
逆风水手1 小时前
Ansible自动化运维入门指南
linux·运维·自动化·ansible
tianyuanwo1 小时前
SSH会话管理实战:识别与清理非法连接的完整指南
运维·ssh
小豆子范德萨1 小时前
两台window配置SSH免密登录
运维·ssh
小北方城市网2 小时前
第 6 课:Vue 3 工程化与项目部署实战 —— 从本地开发到线上发布
大数据·运维·前端·ai
Smile_2542204182 小时前
vlc的使用
网络·webrtc·实时音视频
旖旎夜光3 小时前
Linux(3)(下)
linux·学习