首页
登录
从业资格
请将下面创建销售单表的 SQL 语句补充完整,要求指定关系的主码和外码约束。
请将下面创建销售单表的 SQL 语句补充完整,要求指定关系的主码和外码约束。
admin
2022-08-02
60
问题
请将下面创建销售单表的 SQL 语句补充完整,要求指定关系的主码和外码约束。CREATE TABLE SALES( Sno CHAR(8) (a) VEMno CHAR(5) (b) Gno CHAR(8) (c) SDate DATE, STime TIME);【问题 2】 (4分)创建销售记录详单视图 SALES_Detail ,要求按日期统计每个售货机上各种商品的销售数量,属性有 VEMno、Location 、Gno、Brand 、Price 、amount 和 SDate。为方便实现,首先建立一个视图 SALES_Total ,然后利用SALES_Total 完成视图 SALES_Detail 的定义。CREATE VIEW SALES _Total(VEMno,Gno,SDate,amount) AS SELECT VENno ,Gno ,SDate ,count(*) FROM SALES GROUP BY (d);CREATE VIWE (e) AS SELECT VEM.VEMno,Location ,GOODS.Gno ,Brand,Price,amount,SDate FROM VEM,GOODS,SALES_Total WHERE (f) AND (g)【问题 3】 (3分)每售出一件商品,就自动向销售单中添加一条销售记录。如果一天内某个售货机上某种商品的销售记录达到 10 条,则自动向缺货单中添加一条缺货记录。需要用触发器来实现缺货单的自动维护。程序中的 GetTime( )获取当前时间。CREAT(h) OOS_TRG AFTER (i) ON SALES REFERENCING new row AS nrow FOR EACH ROWBEGIN INSERT INTO OOS SELECT SALES .VENno, (j) GetTime( ) FROMSALES WHERE SALES.VEMno = nrow.VEMno AND SALES.Gno = nrow.Gno AND SALES.SDate = nrow.SDate GROUP BY SALES.VEMno,SALES.Gno,SALES.SDate HAVING count(*)> 0 AND mod(count(*), 10)=0;END【问题 4】 (3分)查询当天销售最多的商品编号、品牌和数量。程序中的 GetDate( )获取当天日期。SELECT GOODS.Gno ,Brand, (k)FROM GOODS,SALESWHERE GOODS.Gno=SALES.GNO AND SDATE =GetDate( ) GROUP BY (1) HAVING(M) (SELECT count(*) FROM SALELS WHERE SDATE = GetDate( ) GROUP BY Gno);【问题5】 (2分)查询一件都没有售出的所有商品编号和品牌。SELECT Gno ,BrandFROM GOODSWHERE GNO(N) SELECT DISTINCT GNO FROM(o);
选项
答案
解析
【问题1】
依据题干中的关系设计(a)处应该为主键的定义,(b)和(c)处应该为外键的定义:
(a)PRIMARY KEY
(b)REFERENCES VEM(VEMno)
(c)REFERENCES GOODS(Gno)
【问题2】
本题是考查创建视图的语法:
CREATE VIEW 视图名(列名 [,· · · n])
AS SELECT 查询子句
(d)处应该制定分组的依据,由于SELECT语句后跟随了 VEMno ,Gno ,SDate这些列,所以(d)处应该列表这些列
(e)处应该为创建视图的名称:SALES_Detail(VEMno,Location,Gno,Brand,Price,Amount,SDate)
(f)和(g)处应该制定查询语句中涉及到的3个关系之间的连接条件:(f)VEM.VEMno=SALES_Total. VEMno ;(g)GOODS.Gno= SALES_Total. Gno;f和g可以互换
【问题3】
本题是考查创建触发器的语句
CREATE TRIGGER 触发器名
[{BEFORE|AFTER}]
{事件}
ON <对象名>
REFERENCING {OLD AS old}|{NEW AS new}
[FOR EACH ROW] [WHEN 条件]
{触发器执行体}
(h)处应该为关键字:TRIGGER
(i)处应该是插入数据时触发,所以应该为INSERT
OOS(VEMno,Gno,SDate, STime)共有4个属性且为全码表,INSERT语句必须插入所有列的值,因此:
(j)处应该为:SALES.Gno,SALES.Sdate
【问题4】
题干中要求返回数量,因此(k)COUNT(*) AS 数量
(l)处是分组的依据,分组的依据为商品编号,由于SELECT 后跟随了列GOODS.Gno,Brand,所以(l)处应为:GOODS.Gno,Brand
(m)处是在分组的基础上制定筛选的条件;而子查询返回的是一系列的单个属性的值的集合,应该使用>=ALL来取得最大值,所以(m)处应填写COUNT(*)>=ALL
【问题5】
依据子查询 SELECT DISTINCT GNO FROM(o);应该是从销售表中查询出有销售记录的商品编号,所以(o)处应为:SALES
(n)处为筛选条件,只有没有出现在销售表中的商品编号,也就意味着没有销售过,因此(n)处应为:NOT IN
转载请注明原文地址:https://tihaiku.com/congyezige/2419932.html
本试题收录于:
中级 数据库系统工程师题库软件水平考试初中高级分类
中级 数据库系统工程师
软件水平考试初中高级
相关试题推荐
在HTML文档中创建一个标记sample,()可以创建指向标记sample的超链
设有一个关系emp-sales(部门号,部门名,商品编号,销售数),查询各部门至
下面有关白盒测试说法错误的是()A."白盒"法是穷举路径测试 B.白盒测
下面是在HTML中使用"<li></li>"标签编写的列表在浏览器中的显示效果,
关于虚拟局域网,下面的描述中错误的是()。A.每个VLAN都类似于一个物理网段
可以采用不同的方法配置VLAN,下面列出的方法中,属于静态配置的是()。A
在需要保证数据安全的前提下,并用来传输大块的数据库,下面那种存储网络架构合适(
下面关于PIPv1的协议的叙述中,正确的是______。A.RIPv1的最大跳数
网络管理员发现网络中充斥着广播和组播包,可通过()解决。A.创建VLAN
某市场调研公司对品牌商品销售情况进行调查后,得到下图(a)所示的销量统计数据。将
随机试题
Diplomatsfromtheinternationalcontactgrouparecallingfor______[br][ori
[originaltext]M:Isthistableinthecornerokay?W:Sure,wecansithere.Be
Although______beforethewar,theengineisstillinperfectorder.A、building
A.approximatelyB.dedicatedC.dispensableD.distinctionE.engage
为建筑内部装修防火工程进行验收时,应对电气设备及灯具的设置进行检查。在对某建筑的
中央银行的货币政策对股票价格有直接的影响。货币政策主要使用的工具有()。 Ⅰ
Thechangeinthatvillagewasmiraculou
碘酊中碘化钾的作用是A.乳化 B.补钾 C.抗氧化 D.助溶 E.脱碘
“鱼和熊掌,两者不可兼得。”这种矛盾心态是动机冲突形式中的()冲突。A.双
刚刚毕业的王某被分配到一所小学担任四年级(3)班的班主任。班里有几名学生特别爱打
最新回复
(
0
)