主观题
-
SQL语言是( )的语言,容易学习。
A. 过程化
B. 非过程化
C. 格式化
D. 导航式
-
在视图上不能完成的操作是( )。
A. 更新视图
B. 查询
C. 在视图上定义新的表
D. 在视图上定义新的视图
-
SQL语言集数据查询、数据操纵、数据定义和数据控制功能于一体,其中,CREATE、DROP、ALTER语句是实现哪种功能( )。
A. 数据查询
B. 数据操纵
C. 数据定义
D. 数据控制
-
SQL语言中,删除一个视图的命令是( )。
A. DELETE
B. DROP
C. CLEAR
D. REMOVE
-
在SQL语言中的视图VIEW是数据库的( )。
A. 外模式
B. 模式
C. 内模式
D. 存储模式
-
下列的SQL语句中,( )不是数据定义语句。
A. CREATE TABLE
B. DROP VIEW
C. CREATE VIEW
D. GRANT
-
若要撤销数据库中已经存在的表S,可用( )。
A. DELETE TABLE S
B. DELETE S
C. DROP TABLE S
D. DROP S
-
若要在基本表S中增加一列CN(课程名),可用( )。
A. ADD TABLE S(CN CHAR(8))
B. ADD TABLE S ALTER(CN CHAR(8))
C. ALTER TABLE S ADD(CN CHAR(8))
D. ALTER TABLE S (ADD CN CHAR(8))
-
学生关系模式S(S#,Sname,Sex,Age),S的属性分别表示学生的学号、姓名、性别、年龄。要在表S中删除一个属性“年龄”,可选用的SQL语句是( )。
A. DELETE Age from S
B. ALTER TABLE S DROP Age
C. UPDATE S Age
D. ALTER TABLE S 'Age'
-
有关系S(S#,SNAME,SAGE),C(C#,CNAME),SC(S#,C#,GRADE)。其中S#是学生号,SNAME是学生姓名,SAGE是学生年龄,C#是课程号,CNAME是课程名称。要查询选修“ACCESS”课的年龄不小于20的全体学生姓名的SQL语句是SELECT SNAM EFROM S,C,SC WHERE子句。这里的WHERE子句的内容是( )。
A. S. S#=SC. S# and C. C#=SC. C# and SAGE>=20 and CNAME='ACCESS'
B. S. S#=SC. S# and C. C#=SC. C# and SAGE in >=20 and CNAME in 'ACCESS'
C. SAGE in >=20 and CNAME in 'ACCESS'
D. SAGE>=20 and CNAME='ACCESS'
-
设关系数据库中一个表S的结构为S(SN,CN,grade),其中SN为学生名,CN为课程名,二者均为字符型;grade为成绩,数值型,取值范围0-100。若要把“张二的化学成绩80分”插入S中,则可用( )。
A. ADD INTO S VALUES('张二', '化学', '80')
B. INSERT INTO S VALUES('张二', '化学', '80')
C. ADD INTO S VALUES('张二', '化学', 80)
D. INSERT INTO S VALUES('张二', '化学', 80)
-
设关系数据库中一个表S的结构为:S(SN,CN,grade),其中SN为学生名,CN为课程名,二者均为字符型;grade为成绩,数值型,取值范围0-100。若要更正王二的化学成绩为85分,则可用( )。
A. UPDATE S SET grade=85 WHERE SN='王二' AND CN='化学'
B. UPDATE S SET grade='85' WHERE SN='王二' AND CN='化学'
C. UPDATE grade=85 WHERE SN='王二' AND CN='化学'
D. UPDATE grade='85' WHERE SN='王二' AND CN='化学'
-
在SQL语言中,子查询是( )。
A. 返回单表中数据子集的查询语言
B. 选取多表中字段子集的查询语句
C. 选取单表中字段子集的查询语句
D. 嵌入到另一个查询语句之中的查询语句
-
有关系S(S#,SNAME,SEX),C(C#,CNAME),SC(S#,C#,GRADE)。其中S#是学生号,SNAME是学生姓名,SEX是性别,C#是课程号,CNAME是课程名称。要查询选修“数据库”课的全体男生姓名的SQL语句是SELECT SNAME FROMS,C,SC WHERE子句。这里的WHERE子句的内容是(A)。
A. S. S#=SC. S# and C. C#=SC. C# and SEX='男' and CNAME='数据库'
B. S. S#=SC. S# and C. C#=S C. C# and SEX in '男'and CNAME in '数据库'
C. SEX '男' and CNAME '数据库'
D. S. SEX='男' and CNAME='数据库'
-
若用如下的SQL语句创建了一个表SC:CREATE TABLE SC(S# CHAR(6) NOT NULL, C# CHAR(3) NOT NULL, SCORE INTEGER, NOTE CHAR(20));向SC表插入如下行时,(B)行可以被插入。
A. ('201009', '111', 60, 必修)
B. ('200823', '101', NULL, NULL)
C. (NULL, '103', 80, '选修')
D. ('201132', NULL, 86, '')
-
假设学生关系S(S#,SNAME,SEX),课程关系C(C#,CNAME),学生选课关系SC(S#,C#,GRADE)。要查询选修“Computer”课的男生姓名,将涉及到关系(D)。
A. S
B. S,SC
C. C,SC
D. S,C,SC
BCCBA、DCCBA、DADAB、D
客观题
-
试述SQL语言的特点。
综合统一。SQL语言集数据定义语言DDL、数据操纵语言DML、数据控制语言DCL的功能于一体。
高度非过程化。用SQL语言进行数据操作,只要提出“做什么”,而无须指明“怎么做”,因此无需了解存取路径,存取路径的选择以及SQL语句的操作过程由系统自动完成。
面向集合的操作方式。SQL语言采用集合操作方式,不仅操作对象、查找结果可以是元组的集合,而且一次插入、删除、更新操作的对象也可以是元组的集合。
以同一种语法结构提供两种使用方式。SQL语言既是自含式语言,又是嵌入式语言。作为自含式语言,它能够独立地用于联机交互的使用方式,也能够嵌入到高级语言程序中,供程序员设计程序时使用。
语言简捷,易学易用。
-
SQL的中文全称是________________。
结构化查询语言
-
试述SQL的定义功能。
SQL的数据定义功能包括定义表、定义视图和定义索引。SQL语言使用CREATE TABLE语句建立基本表,ALTER TABLE语句修改基本表定义,DROP TABLE语句删除基本表;使用CREATE INDEX语句建立索引,DROP INDEX语句删除索引;使用CREATE VIEW命令建立视图,DROP VIEW语句删除视图。
-
SQL语言除了具有数据查询和数据操纵功能之外,还具有________和________的功能,它是一个综合性的功能强大的语言。
数据定义、数据控制
-
在关系数据库标准语言SQL中,实现数据检索的语句命令是________。
SELECT
-
用SQL语句建立第2章习题5中的四个表。
--S(SNO, SNAME, STATUS, CITY) CREATE TABLE S ( SNO CHAR(3), SNAME CHAR(10), STATUS CHAR(2), CITY CHAR(10) ); --P(PNO, PNAME, COLOR, WEIGHT); CREATE TABLE P ( PNO CHAR(3), PNAME CHAR(10), COLOR CHAR(4), WEIGHT INT ); --J(JNO, JNAME, CITY) CREATE TABLE J ( JNO CHAR(3), JNAME CHAR(10), CITY CHAR(10) ); --SPJ(SNO, PNO, JNO, QTY) CREATE TABLE SPJ ( SNO CHAR(3), PNO CHAR(3), JNO CHAR(3), QTY INT );
-
在SQL语言的结构中,________有对应的物理存储,而________没有对应的物理存储。
基本表、视图
-
针对上题中建立的四个表试用SQL语言完成第2章习题5中的查询。
--(1)求供应工程J1零件的供应商号码SNO; SELECT SNO FROM SPJ WHERE JNO='J1'; --(2)求供应工程J1零件P1的供应商号码SNO; SELECT SNO FROM SPJ WHERE JNO='J1' AND PNO='P1'; --(3)求供应工程J1零件为红色的供应商号码SNO; SELECT SNO FROM SPJ WHERE JNO='J1' AND PNO IN (SELECT PNO FROM P WHERE COLOR='红'); --或者: SELECT SNO FROM SPJ, P WHERE JNO='J1' AND SPJ.PNO=P.PNO AND COLOR='红'; --(4)求没有使用天津供应商生产的红色零件的工程号JNO; SELECT JNO FROM J WHERE NOT EXISTS (SELECT * FROM SPJ WHERE SPJ.JNO=J.JNO AND SNO IN(SELECT SNO FROM S WHERE CITY='天津')AND PNO IN(SELECT PNO FROM P WHERE COLOR='红')); --或者 SELECT JNO FROM J WHERE NOT EXISTS(SELECT * FROM SPJ, S, P WHERE SPJ.JNO=J.JNO AND SPJ.SNO=S.SNO AND SPJ.PNO=P.PNO AND S.CITY='天津' AND P.COLOR='红'); --(5)求至少用了供应商S1所供应的全部零件的工程号JNO(类似于P113例44)。 SELECT DISTINCTJNO FROM SPJ SPJZ WHERE NOT EXISTS(SELECT * FROM SPJ SPJX WHERE SNO='S1'AND NOT EXISTS(SELECT * FROM SPJ SPJY WHERE SPJY.PNO=SPJX.PNO AND SPJY.JNO=SPJZ.JNO AND SPJY.SNO='S1'));
-
针对习题3中的四个表试用SQL语言完成以下各项操作:(1)找出所有供应商的姓名和所在城市。(2)找出所有零件的名称、颜色、重量。(3)找出使用供应商S1所供应零件的工程号码。(4)找出工程项目J2使用的各种零件的名称及其数量。(5)找出上海厂商供应的所有零件号码。(6)找出使用上海产的零件的工程名称。(7)找出没有使用天津产的零件的工程号码。(8)把全部红色零件的颜色改成蓝色。(9)由S5供给J4的零件P6改为由S3供应,请作必要的修改。
--(1)找出所有供应商的姓名和所在城市。 SELECT SNAME, CITY FROM S; --(2)找出所有零件的名称、颜色、重量。 SELECT PNAME, COLOR, WEIGHT FROM P; --(3)找出使用供应商S1所供应零件的工程号码。 SELECT JNO FROM SPJ WHERE SNO='S1'; --(4)找出工程项目J2使用的各种零件的名称及其数量。 SELECT P. PNAME, SPJ. QTY FROM P, SPJ WHERE P. PNO=SPJ. PNO AND SPJ. JNO='J2'; --(5)找出上海厂商供应的所有零件号码。 SELECT DISTINCTPNO FROM SPJ WHERE SNO IN(SELECT SNO FROM S WHERE CITY='上海'); --(6)找出使用上海产的零件的工程名称。 SELECT JNAME FROM J, SPJ, S WHERE J. JNO=SPJ. JNO AND SPJ. SNO=S. SNO AND S. CITY='上海'; -- 或 SELECT JNAME FROM J WHERE JNO IN(SELECT JNO FROM SPJ, S WHERE SPJ. SNO=S. SNO AND S. CITY='上海'); --(7)找出没有使用天津产的零件的工程号码。 SELECT JNO FROM J WHERE NOT EXISTS(SELECT * FROM SPJ WHERE SPJ. JNO=J. JNO AND SNO IN(SELECT SNO FROM S WHERE CITY='天津')); --或 SELECT JNO FROM J WHERE NOT EXISTS(SELECT * FROM SPJ, S WHERE SPJ. JNO=J. JNO AND SPJ. SNO=S. SNO AND S. CITY='天津'); --(8)把全部红色零件的颜色改成蓝色。 UPDATE P SET COLOR='蓝' WHERE COLOR='红'; --(9)由S5供给J4的零件P6改为由S3供应, 请作必要的修改。 UPDATE SPJ SET SNO='S3' WHERE SNO='S5' AND JNO='J4' AND PNO='P6'; --(10)从供应商关系中删除S2的记录, 并从供应情况关系中删除相应的记录。 DELETE FROM SPJ WHERE SNO='S2'; DELETE FROM S WHERE SNO='S2'; --解析:注意删除顺序, 应该先从SPJ表中删除供应商S2所供应零件的记录, 然后从从S表中删除S2。 --(11)请将(S2, J6, P4, 200)插入供应情况关系。 INSERT INTO SPJ (SNO,JNO,PNO,QTY) VALUES(S2, J6, P4, 200);
-
关系R(A,B,C)和S(A,D,E,F),R和S有相同属性A,若将关系代数表达式:πR. A,R. B,S. D,S. F(R∞S)用SQL语言的查询语句表示,则为:SELECT R. A, R. B, S. D, S. F FROM R,S WHERE________________。
R. A=S. A
-
什么是基本表?什么是视图?两者的区别和联系是什么?
基本表是本身独立存在的表,在SQL中一个关系就对应一个表。视图是从一个或几个基本表导出的表。视图本身不独立存储在数据库中,是一个虚表。即数据库中只存放视图的定义而不存放视图对应的数据,这些数据仍存放在导出视图的基本表中。视图在概念上与基本表等同,用户可以如同基本表那样使用视图,可以在视图上再定义视图。
-
视图是从________中导出的表,数据库中实际存放的是视图的________。
基本表或视图、定义
-
试述视图的优点。
(1)视图能够简化用户的操作。(2)视图使用户能以多种角度看待同一数据。(3)视图对重构数据库提供了一定程度的逻辑独立性。(4)视图能够对机密数据提供安全保护。
-
关系数据操作语言(DML)的特点是:操作对象与结果均为关系、操作的________、语言一体化并且是建立在数学理论基础之上。
非过程性强
-
设有如下关系表R、S、T:R(BH,XM,XB,DWH)S(DWH,DWM)T(BH,XM,XB,DWH)(1)实现R∪T的SQL语句是。(2)实现σDWH=’100’?的SQL语句是。(3)实现πXM,XB?的SQL语句是。(4)实现πXM,DWH(σXB=’女’?)的SQL语句是。(5)实现R∞S的SQL语句是。(6)实现πXM,XB,DWH(σXB=’男’(R∞S))的SQL语句是。
--1 SELECT * FROM R UNION SELECT * FROM T; --2 SELECT * FROM R WHERE DWH='100'; --3 SELECT XM, XB FROMR; --4 SELECT XM, DWH FROM R WHERE XB='女'; --5 SELECT R.BH, R.XM, R.XB, R.DWH, S.DWM FROM R, S WHERE R.DWH=S.DWH; --6 SELECT R.XM, R. XB, S. DWH FROM R, S WHERE R.DWH=S.DWH AND R.XB='男'
-
所有的视图是否都可以更新?为什么?
不是。视图是不实际存储数据的虚表,因此对视图的更新,最终要转换为对基本表的更新。因为有些视图的更新不能唯一地有意义地转换成对相应基本表的更新,所以,并不是所有的视图都是可更新的。如《概论》3. 5. 1中的视图S_G(学生的学号及他的平均成绩)CREATVIEWS_G(Sno,Gavg)ASSELECTSno,AVG(Grade)/设SC表中“成绩”列Grade为数字型/FROMSCGROUPBYSno;要修改平均成绩,必须修改各科成绩,而我们无法知道哪些课程成绩的变化导致了平均成绩的变化。
-
设有如下关系表R:R(NO,NAME,SEX,AGE,CLASS),主码是NO(1)插入一个记录(25,“李明”,“男”,21,“95031”);。(2)插入“95031”班学号为30,姓名为“郑和”的学生记录;____。(3)将学号为10的学生姓名改为“王华”;_____。(4)将所有“95101”班号改为“95091”;_____。(5)删除学号为20的学生记录;____。(6)删除姓“王”的学生记录;。
(1)INSERT INTO R VALUES(25,"李明","男",21,"95031")
(2)INSERT INTO R(NO,NAME,CLASS)VALUES(30,"郑和","95031")
(3)UPDATE R SET NAME="王华" WHERE NO=10
(4)UPDATE R SET CLASS="95091" WHERE CLASS="95101"
(5)DELETE FROM R WHERE NO=20
(6)DELETE FROM R WHERE NAME LIKE '王'%
-
哪类视图是可以更新的,哪类视图是不可更新的?各举一例说明。
基本表的行列子集视图一般是可更新的。如《概论》3. 5. 3中的例1。若视图的属性来自集函数、表达式,则该视图肯定是不可以更新的。如《概论》3. 5. 3中的S_G视图。
-
请为三建工程项目建立一个供应情况的视图,包括供应商代码(SNO)、零件代码(PNO)、供应数量(QTY)。针对该视图完成下列查询:(1)找出三建工程项目使用的各种零件代码及其数量。(2)找出供应商S1的供应情况。
建视图:CREATE VIEW V_SPJAS SELECT SNO,PNO,QTY FROM SPJ WHERE JNO=(SELECT JNO FROM J WHERE JNAME='三建');
对该视图查询:
(1)找出三建工程项目使用的各种零件代码及其数量。SELECT PNO,QTY FROM V_SPJ;
(2)找出供应商S1的供应情况。SELECT PNO,QTY FROM V_SPJ WHERE SNO='S1';
-
针对习题3建立的表,用SQL语言完成以下各项操作:(1)把对表S的INSERT权限授予用户张勇,并允许他再将此权限授予其他用户。(2)把查询SPJ表和修改QTY属性的权限授给用户李天明。
(1)把对表S的INSERT权限授予用户张勇,并允许他再将此权限授予其他用户。GRANT INSERT ON TABLE S TO 张勇WITH GRANT OPTION;
(2)把查询SPJ表和修改QTY属性的权限授给用户李天明。GRANT SELECT,UPDATE (QTY) ON TABLE SPJ TO 李天明;
-
在嵌入式SQL中是如何区分SQL语句和主语言语句的?
在SQL语句前加上前缀EXECSQL。SQL语句的结束标志则随主语言的不同而不同。例如在PL/1和C中以分号(;)结束,在COBOL中以END-EXEC结束。
-
在嵌入式SQL中是如何解决数据库工作单元与源程序工作单元之间通信的?
数据库工作单元与源程序工作单元之间的通信主要包括:(1)SQL通信区SQLCA,用来向主语言传递SQL语句的执行状态信息,使主语言能够根据此信息控制程序流程。(2)主变量(HostVariable),1)用来实现主语言向SQL语句提供参数。2)将SQL语句查询数据库的结果交主语言进一步处理(3)游标(Cursor),解决集合性操作语言与过程性操作语言的不匹配通过游标逐一获取记录,并赋给主变量,交由主语言进一步处理。(详细解释参见《概论》3. 7. 2)
-
在嵌入式SQL中是如何协调SQL语言的集合处理方式和主语言的单记录处理方式的?
用游标来协调这两种不同的处理方式。游标区是系统为用户开设的一个数据缓冲区,存放SQL语句的执行结果,每个游标区都有一个名字。用户可以通过游标逐一获取记录,并赋给主变量,交由主语言进一步处理。