【计算机三级-数据库技术】操作题大题(第七套)

第七套操作题

第46题

假定要建立一个关于篮球职业联盟的数据库,需管理如下信息:
每个球队有球队名称、所在城市;
每位球员有球员姓名、薪酬;
每场比赛有比赛编号、比赛时间、比赛结果、参加比赛的主场球队、参加比赛的客场球队。
其中带下划线的属性是唯一标识。其他需满足的要求如下:
每位球员只属于一个球队,每个球队拥有多位球员;
每位球员可参加多场比赛,每场比赛有多位球员参加,同时球员参加每场比赛会有相应的数
据统计,包括得分和篮板。
请根据以上描述,试画出相应的ER图。(7分)
将所画的ER图转换为相应的关系模式,并指出其主键。(3分)

(1) ER图如下:

(2)

第47题

SSS

(10分)设在SQL Server?某数据库中有房屋及租赁表,表的定义如下:
CREATE TABLE房屋表(
房屋号char(1O)PRIMARY KEY,
房屋地址char(20)not null:
面积int,
月租金int)
CREATE TABLE租赁表(
房屋号char(10),
租赁日期datetime,
租赁月数int not null,
本次总租金int,
PRIMARY KEY(房屋号,租赁日期),
FOREIGN KEY(房屋号)REFERENCES房屋表(房屋号))
现要创建一个具有如下功能的触发器:每当在租赁表中插入一行数据(房屋号,租赁日期,租赁月数)
时,自动计算出该房屋的本次总租金。请补全下列代码。
🌂
CREATE TRIGGER tri ON 租赁表 FOR INSERT
AS
DELCARE @x int-声明保存月租金的变量
SET@x=(SELECT月租金FROM房屋表VHERE房屋号=(SELECT 房屋号 FROM inserted )
UPDATE租赁表SET本次总租金=租赁月数* @x
FROM租赁表as a JOIN inserted as b
ona.房屋号=b.房屋号
anda.租赁日期=b.租赁日期

评价:

第48题

在SQL Server?某数据库中存在销售单据明细表,其建表语句为:
CREATE TABLE销售单据明细表(
销售单据编号varchar(20),
商品编号varchar(8),
单价money,
数量int
)方
在系统运行一段时间后,此表中有近干万条数据,程序员在数据库中执行如下SQL语句:
SELECT商品编号,Sum(单价*数量)FROM销售单据明细表VHERE单价>150 GROUP BY商品编号

为提高此查询的执行效率,在不改变SQL语句且不进行硬件调整的情况下,请给出提高查询执行效率的方案。(5分)
在运行过程中,发现此系统数据库CPU使用率很高,达到近95%,高峰期间达到100%,且系统内存使用率达到90%,但系统/O很轻。业务人员反映系统操作速度慢。为了提高系统运行速度,在不修改应用程序的前提下,两位工程师提出了两种不同的解决方案:
方案一:为服务器增加1颗CPU
方案二:为服务器增加一倍内存
考虑成本因素,现阶段只能选择一种方案实施。请指出在现有情况下,哪种方案更合理并给出原因。(5分)

SSS

答案:
1、由于运行一段时间后,就有了近千万条数据,说明数据的写入量很大,这种情况下不能使用索引,因为写入量大,所以索引的
维护开销将非常巨大,不仅无法提高效率,反而会降低性能,所以不适合查询优化。由于题目不允许改变SQL语句,所以无法使用反规范化或使用临时表的方式,以空间换取时间。题目同样不允许硬件调整,不允许进行硬件升级。本题最适合的方案是数据表的水平分割,由于商品编号有很多,所以应该按照单价区间进行水平分割。

2、根据题目表述,两种方案都能够提高系统运行速度。但是,即便是平峰时CPU的负载也很高,高峰时甚至达到100%,而内存使用率低于CPU使用率,迫切程度低于CPU的需求。所以在成本有限的前提下,应该选择方案1,增加一颗CPU以缓解CPU的性能压力。选择此方案所得到的效果将高于方案2。

相关推荐
夕除5 分钟前
Mysql--09
数据库·mysql
星马梦缘8 分钟前
数据库作战记录2
数据库·sql
无名-CODING25 分钟前
Docker 部署 Redis:小白一键安装、配置与迁移教程
数据库·redis·bootstrap
IMPYLH36 分钟前
Linux 的 env 命令
linux·运维·服务器·数据库
fobwebs42 分钟前
如何通过phpmyadmin指令来优化数据库表,给数据库“减肥”。
数据库·wordpress·数据库优化·phpmyadmin
syinfo42 分钟前
oracle使用PLSQL导出表数据
数据库·oracle
客梦1 小时前
数据库基础
数据库·笔记
老苏畅谈运维1 小时前
Oracle AI Database 26ai 安装实战
数据库·oracle·oracle 26ai
Rick19931 小时前
SQL优化
数据库·sql
沪漂阿龙1 小时前
掌握MySQL这些函数,SQL水平直接起飞!
数据库·sql·mysql