实验九 存储过程和触发器

题目

  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

相关推荐
代码游侠3 分钟前
学习笔记——数据封包拆包与协议
linux·运维·开发语言·网络·笔记·学习
开开心心_Every3 分钟前
定时管理进程:防止沉迷电脑的软件推荐
xml·java·运维·服务器·网络·数据库·excel
云霄IT5 分钟前
ssh使用代理连接服务器:基本用法使用ncat
运维·服务器·ssh
FIT2CLOUD飞致云5 分钟前
支持IP证书签发、数据库TCP代理,1Panel v2.0.16版本正式发布
linux·运维·服务器·开源·1panel·ip证书
Ccjf酷儿5 分钟前
计算机网络 (郑烇) 5 网络层:控制平面
网络·计算机网络·平面
Q741_1479 分钟前
Linux UDP 服务端 实战思路 C++ 套接字 源码包含客户端与服务端 游戏服务端开发基础
linux·服务器·c++·游戏·udp
神秘面具男039 分钟前
Ansible Playbook 编写与运行
服务器·网络·ansible
北方的流星11 分钟前
华为路由协议重定向配置
运维·网络·华为
SMF191912 分钟前
解决从物理机复制的文件无法粘贴到vm虚拟机centos系统中问题
linux·运维·centos
QQ121546146814 分钟前
Linux CentOS 7配置 Tomcat 系统服务
linux·centos·tomcat