《SQL数据库经典面试题(修改笔试题)(有答案).doc》由会员分享,可在线阅读,更多相关《SQL数据库经典面试题(修改笔试题)(有答案).doc(41页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、28.数据库:抽出部门,平均工资,要求按部门的字符串顺序排序,不能含有human resource部门,employee结构如下:employee_id, employee_name,depart_id,depart_name,wage答:select depart_name, avg(wage)from employee where depart_name human resourcegroup by depart_name order by depart_name-29.给定如下SQL数据库:Test(num INT(4) 请用一条SQL语句返回num的最小值,但不许使用统计功能,如MIN
2、,MAX等答:select top 1 num from Test order by num -33.一个数据库中有两个表:一张表为Customer,含字段ID,Name;一张表为Order,含字段ID,CustomerID(连向Customer中ID的外键),Revenue;写出求每个Customer的Revenue总和的SQL语句。建表 create table customer(ID int primary key,Name char(10)gocreate table order(ID int primary key,CustomerID int foreign key referen
3、ces customer(id) , Revenue float)go-查询select Customer.ID, sum( isnull(Order.Revenue,0) )from customer full join order on( order.customerid=customer.id )group by customer.idselect customer.id,sum(order.revener) from order,customer where customer.id=customerid group by customer.idselect customer.id, s
4、um(order.revener ) from customer full join order on( order.customerid=customer.id ) group by customer.id5数据库(10)a tabel called “performance”contain :name and score,please 用SQL语言表述如何选出score最high的一个(仅有一个)仅选出分数,Select max(score) from performance 仅选出名字,即选出名字,又选出分数:select top 1 score ,name from per order
5、 by scoreselect name1,score from per where score in/=(select max(score) from per).4 有关系 s(sno,sname) c(cno,cname) sc(sno,cno,grade) 1 问上课程 db的学生no select count(*) from c,sc where ame=db and o=oselect count(*) from sc where cno=(select cno from c where ame=db)2 成绩最高的学生号 select sno from sc where grade
6、=(select max(grade) from sc )3 每科大于90分的人数select ame,count(*) from c,sc where o=o and sc.grade90 group by ameselect ame,count(*) from c join sc on o=o and sc.grade90 group by ame数据库笔试题 *建表:dept:deptno(primary key),dname,locemp:empno(primary key),ename,job,mgr,sal,deptno*/ 1 列出emp表中各部门的部门号,最高工资,最低工资se
7、lect max(sal) as 最高工资,min(sal) as 最低工资,deptno from emp group by deptno;2 列出emp表中各部门job为CLERK的员工的最低工资,最高工资select max(sal) as 最高工资,min(sal) as 最低工资,deptno as 部门号 from emp where job = CLERK group by deptno;3 对于emp中最低工资小于1000的部门,列出job为CLERK的员工的部门号,最低工资,最高工资select max(sal) as 最高工资,min(sal) as 最低工资,deptno
8、 as 部门号 from emp as bwhere job=CLERK and 1000(select min(sal) from emp as a where a.deptno=b.deptno) group by b.deptno4 根据部门号由高而低,工资有低而高列出每个员工的姓名,部门号,工资select deptno as 部门号,ename as 姓名,sal as 工资 from emp order by deptno desc,sal asc5 写出对上题的另一解决方法(请补充)6 列出张三所在部门中每个员工的姓名与部门号select ename,deptno from em
9、p where deptno = (select deptno from emp where ename = 张三)7 列出每个员工的姓名,工作,部门号,部门名select ename,job,emp.deptno,dept.dname from emp,dept where emp.deptno=dept.deptno8 列出emp中工作为CLERK的员工的姓名,工作,部门号,部门名select ename,job,dept.deptno,dname from emp,dept where dept.deptno=emp.deptno and job=CLERK9 对于emp中有管理者的员工
10、,列出姓名,管理者姓名(管理者外键为mgr)select a.ename as 姓名,b.ename as 管理者 from emp as a,emp as b where a.mgr is not null and a.mgr=b.empno10 对于dept表中,列出所有部门名,部门号,同时列出各部门工作为CLERK的员工名与工作select dname as 部门名,dept.deptno as 部门号,ename as 员工名,job as 工作 from dept,emp where dept.deptno *= emp.deptno and job = CLERK11 对于工资高于
11、本部门平均水平的员工,列出部门号,姓名,工资,按部门号排序select a.deptno as 部门号,a.ename as 姓名,a.sal as 工资 from emp as awhere a.sal(select avg(sal) from emp as b where a.deptno=b.deptno) order by a.deptno12 对于emp,列出各个部门中平均工资高于本部门平均水平的员工数和部门号,按部门号排序select count(a.sal) as 员工数,a.deptno as 部门号 from emp as awhere a.sal(select avg(sa
12、l) from emp as b where a.deptno=b.deptno) group by a.deptno order by a.deptno13 对于emp中工资高于本部门平均水平,人数多与1人的,列出部门号,人数,按部门号排序select count(a.empno) as 员工数,a.deptno as 部门号,avg(sal) as 平均工资 from emp as awhere (select count(c.empno) from emp as c where c.deptno=a.deptno and c.sal(select avg(sal) from emp as
13、 b where c.deptno=b.deptno)1group by a.deptno order by a.deptno14 对于emp中低于自己工资至少5人的员工,列出其部门号,姓名,工资,以及工资少于自己的人数select a.deptno,a.ename,a.sal,(select count(b.ename) from emp as b where b.sala.sal) as 人数 from emp as awhere (select count(b.ename) from emp as b where b.sal5数据库笔试题及答案第一套一.选择题1. 下面叙述正确的是CCB
14、AD _。A、算法的执行效率与数据的存储结构无关B、算法的空间复杂度是指算法程序中指令(或语句)的条数C、算法的有穷性是指算法必须能在执行有限个步骤之后终止D、以上三种描述都不对2. 以下数据结构中不属于线性数据结构的是_。A、队列B、线性表C、二叉树D、栈3. 在一棵二叉树上第5层的结点数最多是_。A、8 B、16 C、32 D、154. 下面描述中,符合结构化程序设计风格的是_。A、使用顺序、选择和重复(循环)三种基本控制结构表示程序的控制逻辑B、模块只有一个入口,可以有多个出口C、注重提高程序的执行效率 D、不使用goto语句5. 下面概念中,不属于面向对象方法的是_。A、对象 B、继承
15、 C、类 D、过程调用6. 在结构化方法中,用数据流程图(DFD)作为描述工具的软件开发阶段是_ BDBCA _。A、可行性分析 B、需求分析 C、详细设计 D、程序编码7. 在软件开发中,下面任务不属于设计阶段的是_。A、数据结构设计 B、给出系统模块结构 C、定义模块算法 D、定义需求并建立系统模型8. 数据库系统的核心是_。A、数据模型 B、数据库管理系统 C、软件工具 D、数据库9. 下列叙述中正确的是_。A、数据库是一个独立的系统,不需要操作系统的支持B、数据库设计是指设计数据库管理系统C、数据库技术的根本目标是要解决数据共享的问题D、数据库系统中,数据的物理结构必须与逻辑结构一致1
16、0. 下列模式中,能够给出数据库物理存储结构与物理存取方法的是_。A、内模式 B、外模式 C、概念模式 D、逻辑模式11. Visual FoxPro数据库文件是_ DCBAA _。A、存放用户数据的文件 B、管理数据库对象的系统文件C、存放用户数据和系统的文件 D、前三种说法都对12. SQL语句中修改表结构的命令是_。A、MODIFY TABLE B、MODIFY STRUCTURE C、ALTER TABLE D、ALTER STRUCTURE13. 如果要创建一个数据组分组报表,第一个分组表达式是部门,第二个分组表达式是性别,第三个分组表达式是基本工资,当前索引的索引表达式应当是_。A
17、、部门+性别+基本工资 B、部门+性别+STR(基本工资)C、STR(基本工资)+性别+部门 D、性别+部门+STR(基本工资)14. 把一个项目编译成一个应用程序时,下面的叙述正确的是_。A、所有的项目文件将组合为一个单一的应用程序文件B、所有项目的包含文件将组合为一个单一的应用程序文件C、所有项目排除的文件将组合为一个单一的应用程序文件D、由用户选定的项目文件将组合为一个单一的应用程序文件15. 数据库DB、数据库系统DBS、数据库管理系统DBMS三者之间的关系是_。A、DBS包括DB和DBMS B、DBMS包括DB和DBSC、DB包括DBS和DBMS D、DBS就是DB,也就是DBMS1
18、6. 在选项对话框的文件位置选项卡中可以设置_ BAABA _。A、表单的默认大小 B、默认目录C、日期和时间的显示格式 D、程序代码的颜色17. 要控制两个表中数据的完整性和一致性可以设置参照完整性,要求这两个表_。A、是同一个数据库中的两个表 B、不同数据库中的两个表C、两个自由表 D、一个是数据库表另一个是自由表18. 定位第一条记录上的命令是_。A、GO TOP B、GO BOTTOM C、GO 6 D、SKIP19. 在关系模型中,实现关系中不允许出现相同的元组的约束是通过_。A、候选键 B、主键 C、外键 D、超键20. 设当前数据库有10条记录(记录未进行任何索引),在下列三种情
19、况下,当前记录号为1时;EOF()为真时;BOF()为真时,命令?RECN()的结果分别是_。A、1,11,1 B、1,10,1 C、1,11,0 D、1,10,021. 下列表达式中结果不是日期型的是_ CCBBA _。A、CTOD(2000/10/01) B、99/10/01+365 C、VAL(2000/10/01) D、DATE()22. 只有满足联接条件的记录才包含在查询结果中,这种联接为_。A、左联接 B、右联接 C、内部联接 D、完全联接23. 索引字段值不唯一,应该选择的索引类型为_。A、主索引 B、普通索引 C、候选索引 D、唯一索引24. 执行SELECT 0选择工作区的结
20、果是_。A、选择了0号工作区 B、选择了空闲的最小号工作区C、关闭选择的工作区 D、选择已打开的工作区25. 从数据库中删除表的命令是_。A、DROP TABLE B、ALTER TABLE C、DELETE TABLE D、USE26. DELETE FROM S WHERE 年龄60语句的功能是_ BBCCB _。A、从S表中彻底删除年龄大于60岁的记录 B、S表中年龄大于60岁的记录被加上删除标记C、删除S表 D、删除S表的年龄列27. SELECT-SQL语句是_。A、选择工作区语句 B、数据查询语句 C、选择标准语句 D、数据修改语句28. SQL语言是_语言。A、层次数据库 B、网
21、络数据库 C、关系数据库 D、非数据库29. 在SQL中,删除视图用_。A、DROP SCHEMA命令 B、CREATE TABLE命令 C、DROP VIEW命令 D、DROP INDEX命令30. 以下属于非容器类控件的是_。A、Form B、Label C、page D、Container31. 将查询结果放在数组中应使用_d_短语。A、INTO CURSOR B、TO ARRAY C、INTO TABLE D、INTO ARRAY32. 在命令窗口执行SQL命令时,若命令要占用多行,续行符是_d_。A、冒号(:) B、分号(;) C、逗号(,) D、连字符(-)33. 设有图书管理数据
22、库:图书(总编号C(6),分类号C(8),书名C(16),作者C(6),出版单位C(20),单价N(6,2)读者(借书证号C(4),单位C(8),姓名C(6),性别C(2),职称C(6),地址C(20)借阅(借书证号C(4),总编号C(6),借书日期D(8)对于图书管理数据库,查询0001号借书证的读者姓名和所借图书的书名。SQL语句正确的是_。SELECT 姓名,书名 FROM 借阅,图书,读者 WHERE;借阅.借书证号=0001 AND;_a_A、图书.总编号=借阅.总编号 AND;读者.借书证号=借阅.借书证号B、图书.分类号=借阅.分类号 AND;读者.借书证号=借阅.借书证号C、读
23、者.总编号=借阅.总编号 AND;读者.借书证号=借阅.借书证号D、图书.总编号=借阅.总编号 AND;读者.书名=借阅.书名34. 设有图书管理数据库:图书(总编号C(6),分类号C(8),书名C(16),作者C(6),出版单位C(20),单价N(6,2)读者(借书证号C(4),单位C(8),姓名C(6),性别C(2),职称C(6),地址C(20)借阅(借书证号C(4),总编号C(6),借书日期D(8)对于图书管理数据库,分别求出各个单位当前借阅图书的读者人次。下面的SQL语句正确的是_。SELECT 单位,_ FROM 借阅,读者 WHERE;借阅.借书证号=读者.借书证号 a_A、COU
24、NT(借阅.借书证号) GROUP BY 单位 B、SUM(借阅.借书证号) GROUP BY 单位C、COUNT(借阅.借书证号) ORDER BY 单位 D、COUNT(借阅.借书证号) HAVING 单位35. 设有图书管理数据库:图书(总编号C(6),分类号C(8),书名C(16),作者C(6),出版单位C(20),单价N(6,2)读者(借书证号C(4),单位C(8),姓名C(6),性别C(2),职称C(6),地址C(20)借阅(借书证号C(4),总编号C(6),借书日期D(8)对于图书管理数据库,检索借阅了现代网络技术基础一书的借书证号。下面SQL语句正确的是_。SELECT 借书证
25、号 FROM 借阅 WHERE 总编号=;_bA、(SELECT 借书证号 FROM 图书 WHERE 书名=现代网络技术基础)B、(SELECT 总编号 FROM 图书 WHERE 书名=现代网络技术基础)C、(SELECT 借书证号 FROM 借阅 WHERE 书名=现代网络技术基础)D、(SELECT 总编号 FROM 借阅 WHERE 书名=现代网络技术基础)二、填空题36. 算法的复杂度主要包括_复杂度和空间复杂度。37. 数据的逻辑结构在计算机存储空间中的存放形式称为数据的_。38. 若按功能划分,软件测试的方法通常分为白盒测试方法和_测试方法。39. 如果一个工人可管理多个设施,
26、而一个设施只被一个工人管理,则实体工人与实体设备之间存在_联系。40. 关系数据库管理系统能实现的专门关系运算包括选择、连接和_。41. 命令?LEN(THIS IS MY BOOK)的结果是_。42.SQL SELECT语句为了将查询结果存放到临时表中应该使用_短语。43. 多栏报表的栏目数可以通过_来设置。44. 在打开项目管理器之后再打开应用程序生成器,可以通过按ALT+F2键,快捷菜单和工具菜单中的_。45. 数据库系统的核心是_。46. 查询设计器中的联接选项卡,可以控制_选择。47. 设有图书管理数据库:图书(总编号C(6),分类号C(8),书名C(16),作者C(6),出版单位C
27、(20),单价N(6,2)读者(借书证号C(4),单位C(8),姓名C(6),性别C(2),职称C(6),地址C(20)借阅(借书证号C(4),总编号C(6),借书日期D(8)用SQL的CREATE命令建立借阅表(字段顺序要相同),请对下面的SQL语句填空:_48. 设有图书管理数据库:图书(总编号C(6),分类号C(8),书名C(16),作者C(6),出版单位C(20),单价N(6,2)读者(借书证号C(4),单位C(8),姓名C(6),性别C(2),职称C(6),地址C(20)借阅(借书证号C(4),总编号C(6),借书日期D(8)对图书管理数据库,查询由清华大学出版社或电子工业出版社出版
28、,并且单价不超出20元的书名。请对下面的SQL语句填空:SELECT 书名,出版单位,单价 FROM 图书;WHERE_ AND;_49. 设有图书管理数据库:图书(总编号C(6),分类号C(8),书名C(16),作者C(6),出版单位C(20),单价N(6,2)读者(借书证号C(4),单位C(8),姓名C(6),性别C(2),职称C(6),地址C(20)借阅(借书证号C(4),总编号C(6),借书日期D(8)对图书管理数据库,求共借出多少种图书。请对下面的SQL语句填空:SELECT _ FROM 借阅第一套题答案选择题1-5 CCBAD 6-10 BDBCA 11-15 DCBAA 16-
29、20 BAABA 21-25 CCBBA 26-30 BBCCB 31-35 DDAAB填空题36.时间 37.模式或逻辑模式 38.黑盒 39. 一对多 或 1对多 或 一对n 或 1:N 或 1:n 或 1:n 或 1:N 或 一对m 或 1:M 或 1:m 或 1:m 或 1:N 40. 投影 41.15 42. Into cursor 或 Into cursor cursorname 43. 页面设置 或 列数 44. 应用程序生成器 45. 数据库管理系统 或 DBMS 46. 联接类型 或 联接条件 47. CREATE TABLE 借阅 (借书证号 C(4),总编号 C(6),借书日期 D(8) 或 CREA TABL 借阅 (借书证号 C(4),总编号 C(6),借书日期D(8) 或 CREATE TABLE 借阅 (借书证号 C(4),总编号 C(6),借书日期 D) 或 CREA TABL 借阅 (借书证号 C(4),总编号 C(6),借书日期 D) 48. 单价=;ALL (SELECT 工资 FROM 教师 WHERE 系号=02)与如上语句等价的SQL语句是_。A、SELECT DISTINCT 系号 FROM 教师 WHERE工资=;(SELECT MAX(工资) FROM 教师 WHERE
限制150内