假设供应商S和供应情况SPJ的关系模式分别为S(Sno,Snaale,Status,City)和SPJ (Sno,Pno,Jno,Qty)。SQL。语句 (19) 不能正确地查询㈩“零件号Pno等于‘P3’的供应商名Snam”,而 (20) 能正确查询的关系代数表达式。
A.SELECT DISTINCTSname
B.SELECT DISTm CTSname
FROMSFROMS
WHERE EXISTS WHERE 0<
(SELECT* (SELECTCOUNT(*)
FROM SPJ FROM SPJ
WHERE S.Sno=SPJ.SnO WHERE S.Sno;SPJ.Sno
AND SPJ.Pno;,P3,AND SPJ.Pno=’P3’)
C.SELECT Shame
D.SELECT Sname
FROMS FROMS,SPJ
WHERE EXISTS WHERES.Sno=SPJ.Sno
(SELECT* ANDSPJ.Pno=’P3’)
FROM SPJ GROUP BYSname
WHERE S. Sno=SPJ. Sno
AND SPJ. Pno=’P3’)
参考答案:C
解析: SQL语言是一种典型的关系型数据库语言,它包含数据描述语言DDL和数据操纵语言DML。其中,DDL包括数据定义和数据控制,DML包括数据查询和数据修改。SQL的核心是数据库查询语句,语句的一般格式是:
SELECT 目标列
FROM 基本表(或视图)
[WHERE条件表达式]
[GROUPBY 列名1 [HAVING 内部函数表达式))
[ORDERBY 列名2 [ASC或DESC))
整个语句的含义是:根据WHERE子句中的条件表达式,从基本表 (或视图)中找出满足条件的元组,按SELECT子句的目标列,选出元组中的分量形成结果表。如果有ORDER子句,则结果表要根据指定的列名2升序(ASC)或降序(DESC)排序。GROUP子句将结果按列名1分组,每个组产生结果表中的一个元组,通常在每组中作用库函数。分组的附加条件用HAVING短语给出,只有满足内部函数表达式的组才子输出。COUNT函数用来统计元组个数。DISTINCT用来去掉查询结果中重复的行。