数据库经典笔试题和面试题答案

2024-05-10 01:52

1. 数据库经典笔试题和面试题答案

如下这些有关数据库知识考查的经典笔试题,非常全面,对计算机专业毕业生参加笔试会很有帮助,建议大家收藏。
    一、选择题
 
    1. 下面叙述正确的是___c___。
 
    A、算法的执行效率与数据的存储结构无关
 
    B、算法的空间复杂度是指算法程序中指令(或语句)的条数
 
    C、算法的有穷性是指算法必须能在执行有限个步骤之后终止
 
    D、以上三种描述都不对
 
    2. 以下数据结构中不属于线性数据结构的是___c___。
 
    A、队列B、线性表C、二叉树D、栈
 
    3. 在一棵二叉树上第5层的结点数最多是__b____。2的(5-1)次方
 
    A、8 B、16 C、32 D、15
 
    4. 下面描述中,符合结构化程序设计风格的是___a___。
 
    A、使用顺序、选择和重复(循环)三种基本控制结构表示程序的控制逻辑
 
    B、模块只有一个入口,可以有多个出口
 
    C、注重提高程序的执行效率 D、不使用goto语句
 
    5. 下面概念中,不属于面向对象方法的是___d___。
 
    A、对象 B、继承 C、类 D、过程调用
 
    6. 在结构化方法中,用数据流程图(DFD)作为描述工具的软件开发阶段是___b___。
 
    A、可行性分析 B、需求分析 C、详细设计 D、程序编码
 
    7. 在软件开发中,下面任务不属于设计阶段的是__d____。
 
    A、数据结构设计 B、给出系统模块结构 C、定义模块算法 D、定义需求并建立系统模型
 
    8. 数据库系统的核心是___b___。
 
    A、数据模型 B、数据库管理系统 C、软件工具 D、数据库
 
    9. 下列叙述中正确的是__c____。
 
    A、数据库是一个独立的系统,不需要操作系统的支持
 
    B、数据库设计是指设计数据库管理系统
 
    C、数据库技术的根本目标是要解决数据共享的问题
 
    D、数据库系统中,数据的物理结构必须与逻辑结构一致
 
    10. 下列模式中,能够给出数据库物理存储结构与物理存取方法的是___a___。
 
    A、内模式 B、外模式 C、概念模式 D、逻辑模式
 
    11. Visual FoxPro数据库文件是___d___。
 
    A、存放用户数据的文件 B、管理数据库对象的系统文件
 
    C、存放用户数据和系统的文件 D、前三种说法都对
 
    12. SQL语句中修改表结构的命令是___c___。
 
    A、MODIFY TABLE B、MODIFY STRUCTURE
 
    C、ALTER TABLE D、ALTER STRUCTURE
 
    13. 如果要创建一个数据组分组报表,第一个分组表达式是"部门",第二个分组表达式是"性别",第三个分组表达式是"基本工资",当前索引的索引表达式应当是__b____。
 
    A、部门+性别+基本工资 B、部门+性别+STR(基本工资)
 
    C、STR(基本工资)+性别+部门 D、性别+部门+STR(基本工资)
 
    14. 把一个项目编译成一个应用程序时,下面的叙述正确的是___a___。
 
    A、所有的项目文件将组合为一个单一的应用程序文件
 
    B、所有项目的包含文件将组合为一个单一的应用程序文件
 
    C、所有项目排除的文件将组合为一个单一的应用程序文件
 
    D、由用户选定的项目文件将组合为一个单一的应用程序文件
 
    15. 数据库DB、数据库系统DBS、数据库管理系统DBMS三者之间的关系是_a___。
 
    A、DBS包括DB和DBMS B、DBMS包括DB和DBS
 
    C、DB包括DBS和DBMS D、DBS就是DB,也就是DBMS
 
    16. 在"选项"对话框的"文件位置"选项卡中可以设置___b___。
 
    A、表单的默认大小 B、默认目录
 
    C、日期和时间的显示格式 D、程序代码的颜色
 
    17. 要控制两个表中数据的完整性和一致性可以设置"参照完整性",要求这两个表_a_。
 
    A、是同一个数据库中的两个表 B、不同数据库中的两个表
 
    C、两个自由表 D、一个是数据库表另一个是自由表
 
    18. 定位第一条记录上的命令是___a___。
 
    A、GO TOP B、GO BOTTOM C、GO 6 D、SKIP
 
    19. 在关系模型中,实现"关系中不允许出现相同的元组"的约束是通过__b____。
 
    A、候选键 B、主键 C、外键 D、超键
 
    20. 设当前数据库有10条记录(记录未进行任何索引),在下列三种情况下,当前记录号为1时;EOF()为真时;BOF()为真时,命令?RECN()的结果分别是___a___。
 
    A、1,11,1 B、1,10,1 C、1,11,0 D、1,10,0
 
    21. 下列表达式中结果不是日期型的是___c___。
 
    A、CTOD("2000/10/01") B、{^99/10/01}+365
 
    C、VAL("2000/10/01") D、DATE()
 
    22. 只有满足联接条件的记录才包含在查询结果中,这种联接为___c___。
 
    A、左联接 B、右联接 C、内部联接 D、完全联接
 
    23. 索引字段值不唯一,应该选择的索引类型为___b___。
 
    A、主索引 B、普通索引 C、候选索引 D、唯一索引
 
    24. 执行SELECT 0选择工作区的结果是___b___。
 
    A、选择了0号工作区 B、选择了空闲的最小号工作区
 
    C、关闭选择的工作区 D、选择已打开的工作区
 
    25. 从数据库中删除表的命令是___a___。
 
    A、DROP TABLE B、ALTER TABLE C、DELETE TABLE D、USE
 
    26. DELETE FROM S WHERE 年龄>60语句的功能是__b____。
 
    A、从S表中彻底删除年龄大于60岁的记录
 
    B、S表中年龄大于60岁的记录被加上删除标记
 
    C、删除S表 D、删除S表的年龄列       1    2

数据库经典笔试题和面试题答案

2. 数据库常见笔试面试题

 数据库常见笔试面试题
                      数据库常见笔试面试题有哪些?数据库常见笔试面试会考什么?下面是数据库常见面试题总结,为大家提供参考。
    
     1、SQL的表连接方式有哪些? 
    SQL中连接按结果集分为:内连接,外连接,交叉连接
    内连接:inner join on,两表都满足的组合。内连接分为等值连接,不等连接,自然连接。
    等值连接:两表中相同的列都会出现在结果集中。
    自然连接:两表中具体相同列表的列会合并为同一列出现在结果集中。
    外连接:分为左(外)连接,右(外)连接,全连接
    左(外)连接:A left (outer) join B,以A表为基础,A表的全部数据,B表有的组合,没有的为null。
    右(外)连接:A right(outer) join B,以B表为基础,B表的全部数据,A表有的组合,没有的位null。
    全连接:A full (outer) join 两表相同的组合在一起,A表有,B表没有的数据(显示为null),同样B表有,A表没有的显示为null。
    交叉连接:cross join,就是笛卡尔乘积。
     2、三范式 
    1NF:表中的字段都是单一属性,不再可分。
    2NF:在1NF的基础上,表中所有的非主属性都必须完全依赖于任意一组候选键,不能仅依赖于候选键中的某个属性。
    3NF:在2NF的基础上,表中所有的属性都不依赖其他非主属性。
    简单的说就是:1NF表示每个属性不可分割,2NF表示非主属性不存在对主键的部分依赖,3NF表示不存在非主属性对主键的依赖传递。
     3、表的操作 
    表的创建:create table 表名 (列名1 类型 约束,列2 类型 约束…)
    表的删除: 表名
    表的更改(结构的更改,不是记录的更新):alter table 表名 add|drop 列名|约束名
    插入记录: into 表名…values…
    更新记录:表名 set 列名=值 where 条件
    删除记录: from 表名 where 条件
     4、数据的完整性 
    数据完整性指的是存储在数据库中的数据的一致性和准确性。
    完整性分类:
    (1)实体完整性:主键值必须唯一且非空。(主键约束)
    (2) 引用完整性(也叫参照完整性):外键要么为空,要么引用主表中存在的记录。(外键约束)。
    (3)用户自定义完整性:针对某一具体关系数据库中的约束条件。
     5、SQL的查询优化 
    (1)从表连接的角度优化:尽量使用内连接,因为内连接是两表都满足的行的组合,而外连接是以其中一个表的全部为基准。
    (2)尽量使用存储过程代替临时写SQL语句:因为存储过程是预先编译好的SQL语句的集合,这样可以减少编译时间。
    (3)从索引的角度优化:对那些常用的查询字段简历索引,这样查询时值进行索引扫描,不读取数据块。
    (4)还有一些常用的select优化技巧:
    (5)A.只查询那些需要访问的字段,来代替select*
    B、将过滤记录越多的where语句向前移:在一个SQL语句中,如果一个where条件过滤的数据库记录越多,定位越准确,则该where条件越应该前移。
     6、索引的作用,聚集索引与非聚集索引的区别 
    索引是一个数据库对象,使用索引,可以是数据库程序无须对整个数据进行扫描,就可以在其中找到目标数据,从而提高查找效率。索引的底层采用的是B树。
    聚集索引:根据记录的key再表中排序数据行。
    非聚集索引:独立于记录的结构,非聚集所以包含的`key,且每个键值项都有指向该简直的数据行的指针。
    聚集索引与非聚集索引的区别:
    (1)聚集索引的物理存储按索引排序,非聚集所以的物理存储不按索引排序。
    (2) 聚集索引插入,更新数据的速度比非聚集索引慢,单查询速度更快。
    (3) 聚集索引的叶级结点保存的是时间的数据项,而非聚集结点的叶级结点保存的是指向数据项的指针。
    (4)一个表只能有一个聚集索引(因为只有一种排序方式),但可以有多个非聚集索引。
     7、存储过程与函数的区别 
    (1)函数有返回值,存储过程没有返回值。
    (2) 因为存储过程没有返回值,所以不能将存储过程的执行结果赋值给变量;函数有返回值类型,调用函数时,可以将函数的执行结果赋值给变量。也就是说,函数可以在select语句中使用,而存储过程则不能。
    
  ;

3. 面试常问的数据库问题及答案

目前在职场中很难找到非常合格的数据库开发人员。有人说:“SQL开发是一门语言,它很容易学,但是很难掌握。” 
在面试应聘的SQL Server数据库开发人员时,我运用了一套标准的基准技术问题。下面这些问题是我觉得能够真正有助于淘汰不合格应聘者的问题。它们按照从易到难的顺序排列。当你问到关于主键和外键的问题时,后面的问题都十分有难度,因为答案可能会更难解释和说明,尤其是在面试的情形下。 
你能向我简要叙述一下SQL Server 2000中使用的一些数据库对象吗? 
你希望听到的答案包括这样一些对象:表格、视图、用户定义的函数,以及存储过程;如果他们还能够提到像触发器这样的对象就更好了。如果应聘者不能回答这个基本的问题,那么这不是一个好兆头。 
NULL是什么意思? 
NULL(空)这个值是数据库世界里一个非常难缠的东西,所以有不少应聘者会在这个问题上跌跟头您也不要觉得意外。 
NULL这个值表示UNKNOWN(未知):它不表示“”(空字符串)。假设您的SQL Server数据库里有ANSI_NULLS,当然在默认情况下会有,对NULL这个值的任何比较都会生产一个NULL值。您不能把任何值与一个 UNKNOWN值进行比较,并在逻辑上希望获得一个答案。您必须使用IS NULL操作符。 
  
什么是索引?SQL Server 2000里有什么类型的索引? 
任何有经验的数据库开发人员都应该能够很轻易地回答这个问题。一些经验不太多的开发人员能够回答这个问题,但是有些地方会说不清楚。 
简单地说,索引是一个数据结构,用来快速访问数据库表格或者视图里的数据。在SQL Server里,它们有两种形式:聚集索引和非聚集索引。聚集索引在索引的叶级保存数据。这意味着不论聚集索引里有表格的哪个(或哪些)字段,这些字段都会按顺序被保存在表格。由于存在这种排序,所以每个表格只会有一个聚集索引。非聚集索引在索引的叶级有一个行标识符。这个行标识符是一个指向磁盘上数据的指针。它允许每个表格有多个非聚集索引。 
什么是主键?什么是外键? 
主键是表格里的(一个或多个)字段,只用来定义表格里的行;主键里的值总是唯一的。外键是一个用来建立两个表格之间关系的约束。这种关系一般都涉及一个表格里的主键字段与另外一个表格(尽管可能是同一个表格)里的一系列相连的字段。那么这些相连的字段就是外键。 
什么是触发器?SQL Server 2000有什么不同类型的触发器? 
让未来的数据库开发人员知道可用的触发器类型以及如何实现它们是非常有益的
 
触发器是一种专用类型的存储过程,它被捆绑到SQL Server 2000的表格或者视图上。在SQL Server 2000里,有INSTEAD-OF和AFTER两种触发器。INSTEAD-OF触发器是替代数据操控语言(Data Manipulation Language,DML)语句对表格执行语句的存储过程。例如,如果我有一个用于TableA的INSTEAD-OF-UPDATE触发器,同时对这个表格执行一个更新语句,那么INSTEAD-OF-UPDATE触发器里的代码会执行,而不是我执行的更新语句则不会执行操作。 
AFTER触发器要在DML语句在数据库里使用之后才执行。这些类型的触发器对于监视发生在数据库表格里的数据变化十分好用。 
您如何确一个带有名为Fld1字段的TableB表格里只具有Fld1字段里的那些值,而这些值同时在名为TableA的表格的Fld1字段里? 
这个与关系相关的问题有两个可能的答案。第一个答案(而且是您希望听到的答案)是使用外键限制。外键限制用来维护引用的完整性。它被用来确保表格里的字段只保存有已经在不同的(或者相同的)表格里的另一个字段里定义了的值。这个字段就是候选键(通常是另外一个表格的主键)。 
另外一种答案是触发器。触发器可以被用来保证以另外一种方式实现与限制相同的作用,但是它非常难设置与维护,而且性能一般都很糟糕。由于这个原因,微软建议开发人员使用外键限制而不是触发器来维护引用的完整性。 
对一个投入使用的在线事务处理表格有过多索引需要有什么样的性能考虑? 
你正在寻找进行与数据操控有关的应聘人员。对一个表格的索引越多,数据库引擎用来更新、插入或者删除数据所需要的时间就越多,因为在数据操控发生的时候索引也必须要维护。 
你可以用什么来确保表格里的字段只接受特定范围里的值? 
这个问题可以用多种方式来回答,但是只有一个答案是“好”答案。您希望听到的回答是Check限制,它在数据库表格里被定义,用来限制输入该列的值。 
触发器也可以被用来限制数据库表格里的字段能够接受的值,但是这种办法要求触发器在表格里被定义,这可能会在某些情况下影响到性能。因此,微软建议使用Check限制而不是其他的方式来限制域的完整性。 
如果应聘者能够正确地回答这个问题,那么他的机会就非常大了,因为这表明他们具有使用存储过程的经验。 
返回参数总是由存储过程返回,它用来表示存储过程是成功还是失败。返回参数总是INT数据类型。 
OUTPUT参数明确要求由开发人员来指定,它可以返回其他类型的数据,例如字符型和数值型的值。(可以用作输出参数的数据类型是有一些限制的。)您可以在一个存储过程里使用多个OUTPUT参数,而您只能够使用一个返回参数。 
什么是相关子查询?如何使用这些查询? 
经验更加丰富的开发人员将能够准确地描述这种类型的查询。 
相关子查询是一种包含子查询的特殊类型的查询。查询里包含的子查询会真正请求外部查询的值,从而形成一个类似于循环的状况。

面试常问的数据库问题及答案

4. 数据库笔试问题

有问题再追问,望采纳。
1、定义固定长度非Unicode字符型局部变量S,且长度为6的命令是declare @S char(10)。
2、表达式6!8=的值是 true,表达式(9=8)and(5<6)的值为false。
3、表达式STR(123.645,8,2)的值的 123.64。
4、表约束是SQL Server 提供的一种强制实现数据完整性的机制,包括:主键约束、外键约束、唯一键约束、检查约束、默认值约束、级联参照完整新约束
5、定义日期时间局部变量DT的命令是:declare @DT datetime。
6、实体之间的联系可以有3种:1对1、1对多和多对多。
7、表达式LEN(‘beijing’)的值是7。
8、在T-SQL中可以使用两种类型的注释字符:单行注释和多行注释。

5. 数据库考试题,望高人指点

a)关系
b)数据库文件 .mdb  日志文件 .ldf
c)主关键字约束,外关键字约束,唯一约束,检查约束和缺省约束
d)聚集索引和非聚集索引
e)windows验证模式和混合验证模式
f)AFTER 触发器和INSTEAD OF 触发器 其中AFTER 触发器即为SQL Server 2000 版本以前所介绍的触发器。该类型触发器要求只有执行某一操作(INSERT UPDATE DELETE) 之后,触发器才被触发,且只能在表上定义。可以为针对表的同一操作定义多个触发器。对于AFTER 触发器,可以定义哪一个触发器被最先触发,哪一个被最后触发,通常使用系统过程sp_settriggerorder 来完成此任务。

    INSTEAD OF 触发器表示并不执行其所定义的操作(INSERT、 UPDATE、 DELETE),而仅是执行触发器本身。既可在表上定义INSTEAD OF 触发器,也可以在视图上定义INSTEAD OF 触发器,但对同一操作只能定义一个INSTEAD OF 触发器。

数据库考试题,望高人指点

6. 请教一个数据库的题目:

1. select distinct 姓名 from S where 系名='计算机'
2.select distinct 姓名,系名 from S where 年龄< 18 and  性别 ='男'
3.select distinct S.姓名 from S ,X,C where X.学号 = S.学号 and X.课程号 =C.课程号 and C.课程名='数据库技术'
4.select distinct C.课程名 from S ,X,C where X.学号 = S.学号 and X.课程号 =C.课程号 and S.姓名='李小明'
5.select distinct S.姓名 from S ,X,C where X.学号 = S.学号 and X.课程号 =C.课程号 and X.成绩 > 90
6.select distinct S.姓名,S.系名,C.课程名 
from S ,X,C where X.学号 = S.学号 and X.课程号 =C.课程号 and X.成绩 < 60

7. 这几道关于数据库的题怎么做?

第一范式

定义:如果关系R 中所有属性的值域都是单纯域,那么关系模式R是第一范式的
第二范式

存在非主属性对码的传递性依赖 R(A,B,C) A是码 A -->B ,B-->C

定义:如果关系模式R是第一范式的,而且关系中每一个非主属性不部分依赖于主键,称R是第二范式的。
第三范式

不存在非主属性对码的传递性依赖以及部分性依赖 ,

1、学号决定姓名,学号、课程号决定成绩,存在非主属性部分依赖于主键,满足第一范式不满足第二范式,是第一范式
2、第三范式
3、学号决定所在系,所在系决定地址,存在传递依赖,满足第二范式,不满足第三范式,是第二范式
4、员工编号决定基本工资和奖金,岗位级别决定岗位工资,员工编号和岗位级别是主键,存在非主属性部分依赖于主键,满足第一范式不满足第二范式,是第一范式
5、如果每个零件都只有一个供应商,零件号是主键,第三范式

这几道关于数据库的题怎么做?

8. 一个很基础的数据库问题,正在考试很着急,在线等待大神解答

肯定是不符合的。
2NF:唯一主键,不存在某个属性只依赖主键的一部分。
3NF:不存在传递依赖,就是某个属性靠一个非主键属性就可以唯一确定。

根据以上的定义,(sno,cno)是表的主键,而sdept只依靠sno就可以确定,因此不满足2NF,也就不满足3NF了。
为了满足题意,所以不能直接修改成3NF,所以做以下的修改满足2NF:

S-L(SNO,Sdept,Sloc) S-C(SNO,Cno,G)
这样SNO是S-L主键,Sdept,Sloc唯一依赖SNO,而(SNO,CNO)是S-C主键,G唯一依赖(SNO,CNO)。
但是,Sloc可由Sdept唯一确定,所以这个解其实不满足3NF。
做以下的修改转换为3NF。
S-D(SNO, Sdept) D-L(Sdept,Sloc),S-C(SNO,CNO,G)
问题解决了。
这种问题你就明确的记住2NF和3NF的规则,然后就把每个表的主键弄出来,把非主键和其他字段进行比较,判断是否唯一由全部主键确定就好。