首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
设某超市经营管理系统使用SQL Server 2008数据库管理系统,此数据库服务器有2颗CPU、16GB内存、2TB磁盘。上线运行1年后,用户在生成每天每个销售人员及每个收银台的总销售额报表时速度缓慢。经技术人员分析,发现速度缓慢的原因为销售单据表和销售
设某超市经营管理系统使用SQL Server 2008数据库管理系统,此数据库服务器有2颗CPU、16GB内存、2TB磁盘。上线运行1年后,用户在生成每天每个销售人员及每个收银台的总销售额报表时速度缓慢。经技术人员分析,发现速度缓慢的原因为销售单据表和销售
admin
2015-07-24
85
问题
设某超市经营管理系统使用SQL Server 2008数据库管理系统,此数据库服务器有2颗CPU、16GB内存、2TB磁盘。上线运行1年后,用户在生成每天每个销售人员及每个收银台的总销售额报表时速度缓慢。经技术人员分析,发现速度缓慢的原因为销售单据表和销售单据明细表数据量合计已经达到60GB。已知这两个表结构如下:
销售单据表(销售单据编号,销售时间,销售人员编号,收银台编号)
销售单据明细表(销售单据编号,商品编号,单价,数量)
在进行此报表计算时数据库服务器CPU消耗非常高。为了优化此操作,某工程师建议在销售单据表中增加"付款总金额"属性,取值由触发器自动计算。请从磁盘空间使用、销售操作时对数据库服务器的影响、数据一致性以及对总销售额计算速度影响方面分析此方案优劣。请判断此方案是否可行,并从时空代价和优化效果方面分析原因。
选项
答案
此方案不可行。触发器可以通过数据库中的相关表进行层叠更改,这比直接把代码写在前台的做法更安全合理,保证了数据的一致性,但同时增加了磁盘空间的消耗。在超市经营中要批量操作、多次触发的情况下,触发器的效率低,因为它相当于每次都执行一段SQL语句,使cpu的消耗更高。因而从时空代价角度来说并不能达到优化的效果,故该方案不可行。
解析
在数据库设计阶段,主要强调的是高效率利用存储空间,减少数据的冗余,减少数据的不一致性,这个过程也就是规范化的过程。但是在数据库运行阶段要考虑到高效率的进行数据处理。
完全规划化的数据库会产生很多表,对于一个频繁使用的查询,如果它要求操作多个相关表中的数据,则每次为生成需要的查询结果而在连接多个表中相关行时,数据库管理系统就会消耗更多的计算资源,因为连接操作非常耗时。
而反规范化是将规范化的关系转换为非规范化的关系的过程,目的是提高查询的效率。常见的方法有增加派生冗余列,增加冗余列,重新组表,分割表和新增汇总表等方法。
该题解决的方式就是增加派生冗余列--"付款总金额"。派生性冗余列是指表中增加的列由表中的一些数据项经过计算而成,它的作用是查询时减少连接操作,避免使用聚合函数。例如销售单据明细表(销售单据编号,商品编号,单价,数量)中增加"付款总金额",因为付款总金额=单价*数量得到,说明"付款总金额"是派生性冗余列。如果不要该字段,那么每次使用总价时,都要先执行代码计算后才能使用,如果商品数量较多,而且要频繁使用"付款总金额"时,计算"付款总金额"时执行的次数也会随着增加,这显然会影响数据库的执行效率。若增加"付款总金额"这个派生性冗余字段,虽然破坏了规范化原则,但只要执行一次计算"付款总金额"就可以把商品金额存在数据库中,以后不管什么时候使用"付款总金额"字段,只需要提取其值就可以了,不必在执行代码了。因此增加"付款总金额",虽然提高了磁盘空间的使用,但是可以提高系统执行的效率,达到以空间换时间的目的。
由此可以看出,在数据单据表中增加"付款总金额"不是正确的优化方法,应该在数据单据明细表中增加"付款总金额",这样才能提高查询效率。
转载请注明原文地址:https://kaotiyun.com/show/CblZ777K
本试题收录于:
三级数据库技术题库NCRE全国计算机三级分类
0
三级数据库技术
NCRE全国计算机三级
相关试题推荐
规范化理论是关系数据库进行逻辑设计的理论依据。根据这个理论,关系数据库的关系必须满足:其中每一属性都是
设计批处理多道系统时,首先要考虑的是
设散列函数为H(k)=kmod7,现欲将关键码23,14,9,6,30,12,18依次散列于地址0~6中,用线性探测法解决冲突,则在地址空间0~6中,得到的散列表是
关系规范化过程就是通过关系模式的分解,把低一级的关系模式分解为若干高一级的关系模式的过程;1NF,2NF,3NF,BCNF之间存在着【】的关系。
在响应比最高者优先的作业调度算法中,当各个作业等待时间相同时,【】的作业将得到优先调度;当各个作业要求运行的时间相同时,等待时间长的作业得到优先调度。
关系数据模型通常由3部分组成,它们是
在SQL中,模式对应于“基本表”,内模式对应于“存储文件”,外模式对应于“【】”和部分基表。
SQL语言集【】、数据操纵、数据定义、数据控制功能于一体。
操作系统的发展过程是
随机试题
ManyvisitorsfindthefastpaceatwhichAmericanpeoplemoveverythroubling.One’sfirstimpressionislikelytobethatever
A.没有知名血管供血,在设计皮瓣时,其长宽比例要受到一定限制的带蒂皮瓣B.通过肌组织发出营养支,垂直穿透深筋膜至皮下组织及皮肤的游离皮瓣C.营养皮肤的动脉在穿出深筋膜后与皮肤表面平行,走行于皮下组织内,并沿途发出小支以供养皮下组织及皮肤的游离皮瓣D.
A.有效性B.安全性C.稳定性D.均一性在规定的适应症、用法和用量条件下,能满足预防、治疗、诊断人的疾病,有目的地调节人的生理机能的要求,体现药品的
具有杀菌作用的紫外线波段是UV-C。()
某市南区居民乙在本市北区因涉嫌销售淫秽光盘被北区公安局处以拘留10天、没收全部光盘的处罚,乙对挽留和没收财物均不服,提起诉讼。问下列说法哪个是正确的?()
我国资产负债表通常采用()格式。
年度生产计划是企业年度经营计划的核心,计划期为()年。
关于票据结算的相关规定,下列说法不正确的是()。
2001年,国家“十五”计划纲要专门列出“实施人才战略,壮大人才队伍”一章,首次将()作为国民经济和社会发展规划的一个重要组成部分。
A、Tohelppeopleunderstandhorsesbetter.B、Tohelppeopleenjoyafamilyatmosphere.C、Tohelppeoplehavefunaboveotherthi
最新回复
(
0
)