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

2024-05-06 09:58

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、定义固定长度非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中可以使用两种类型的注释字符:单行注释和多行注释。

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. 数据仓库面试题

一般数据仓库面试会面两轮,第一轮一般是sql技术面,第二轮就是 维度建模 和 数据治理 的问题。
  
  一轮技术面(待补充): 
  
 1、数据倾斜:
  
 数据倾斜一般产生的原因是数据在map端hash分配到reduce端时,某一个key的数量远大于其他的key,导致某一个reduce的处理时间较长。
  
 1)key分布不均匀 
  2)数据本身就是如此
  3)数据关联时没有把握好关联键
  
 解决方案
  
 1)参数调整:hive.map.aggr = true;hive.groupby.skewindata=true;
   当存在数据倾斜时开启负载均衡,此时会生成两个MapReduce任务,第一个MR任务会将map端产生的key随机的分配到reduce,先进行一次聚合,第二个MR任务会将第一个任务的预处理结果作为输入,将相同的key分配到同一个reduce当中。
  2)sql调整:在处理大量空值导致数据倾斜的情况下,可以先将空值附一个特殊值去处理,比如给一个随机数加字符串的方式,因为空值数据是关联不上的,不会影响后期处理。
  
 2、order by,sort by,cluster by,distribute by的区别
  
 1)order by是全局排序,排序过程在一个reduce中进行,在数据量较大时就会很慢
  2)sort by是局部排序,排序结果在同一个reduce中使有序的
  3)distribute by是将数据按照字段划分到一个reduce中,一般与sort by连用进行分组排序的作用
  4)cluster by除具有distribute by功能外还具有sort by的功能
  
 order by优化(阿里面试):
  1)开启严格模式,order by之后添加limit子句
  2)利用sort by,在每个reduce中先排序取出top项,再把预处理结果order by输出
  
 3、hive中内部表和外部表的区别
  
 1)在创建表的时候,内部表是将数据移动到数据仓库指向的路径,外部表仅记录数据所在的路径,不对数据的位置做任何改变。
  2)在删除表的时候,内部表会将元数据和数据都删除,外部表只删除元数据。
  
 4、列转行、行转列
  
 1)列转行:lateral view explode(split('column_name',','))作为一个新表
  2)行转列:concat_ws(',',collect_set(column_name))
  
 5、mapreduce运行原理
                                          
 6、数据仓库分层原理(阿里面试)
  
 7、维度建模中三种事实表的应用场景(阿里面试)
  
  二轮面试(待补充)

5. 数据库的面试会问什么问题

目前在职场中很难找到非常合格的数据库开发人员。有人说:“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参数,而您只能够使用一个返回参数。 
什么是相关子查询?如何使用这些查询? 
经验更加丰富的开发人员将能够准确地描述这种类型的查询。 
相关子查询是一种包含子查询的特殊类型的查询。查询里包含的子查询会真正请求外部查询的值,从而形成一个类似于循环的状况。

数据库的面试会问什么问题

6. 数据库面试常问问题有哪些?

1、什么是数据库事务
数据库事务是构成单一逻辑工作单元的操作集合。数据库事务可以包括一个或多个数据库操作,但是这些操作构成一个逻辑上的整体。
2、数据库事务的四个特性(ACID)
A:原子性,事务中的所有操作作为一个整体不可分割,要么全部操作要么全部不操作。
C:一致性,事务的执行结果必须使数据库从一个一致性状态转为另一个一致性状态。一致性状态:1.系统状态满足数据库的完整性约束,2.系统的状态反映数据库所描述的现实世界的真实状态。
I:隔离性:并发执行的事务不会相互影响,其对数据库的影响和他们串行执行时一样。
D:持久性:事务一旦提交,对数据库的影响就是持久的。任何事务或系统故障都不会导致数据丢失。
3、什么是数据库连接泄露
数据库连接泄露指的是如果在某次使用或者某段程序中没有正确地关闭Connection、Statement和ResultSet资源,那么每次执行都会留下一些没有关闭的连接,这些连接失去了引用而不能得到重新使用,因此就造成了数据库连接的泄漏。数据库连接的资源是宝贵而且是有限的,如果在某段使用频率很高的代码中出现这种泄漏,那么数据库连接资源将被耗尽,影响系统的正常运转。

4、聚集索引
数据行的物理顺序与列值的顺序相同,如果我们查询id比较靠后的数据,那么这行数据的地址在磁盘中的物理地址也会比较靠后。而且由于物理排列方式与聚集索引的顺序相同,所以也就只能建立一个聚集索引了。
5、主键与外键
关系型数据库中的一条记录中有若干个属性,若其中某一个属性组(注意是组)能唯一标识一条记录,该属性组就可以成为一个主键。
外键用于与另一张表的关联。是能确定另一张表记录的字段,用于保持数据的一致性。比如,A表中的一个字段,是B表的主键,那他就可以是A表的外键。

7. SQL数据分析面试题

 1、现有交易数据表user_goods_table,
                                           老板想知道每个用户购买的外卖品类偏好分布,并找出每个用户购买最多的外卖品类是哪个。
   2、现有交易数据表user_sales_table,
                                           老板想知道支付金额在前20%的用户。
   3、现有用户登录表user_login_table,
                                           老板想知道连续7天都登录平台的重要用户。
   4、给定一张用户签到表user_attendence,表中包含三个字段,分别是用户ID:【user_id】,日期:【date】,是否签到:【is_sign_in】,0否1是。
   4-1、计算截至当前(假设当前时间为2020-04-27),每个用户已经连续签到的天数:
   要求输出用户ID【user_id】和连续签到天数【recent_continuous_days】
   4-2、计算有史以来 用户最大连续签到天数 :
   要求输出用户ID【user_id】和最大连续签到天数

SQL数据分析面试题

8. 数据库面试常问问题有哪些?

1、什么是数据库事务
数据库事务是构成单一逻辑工作单元的操作集合。数据库事务可以包括一个或多个数据库操作,但是这些操作构成一个逻辑上的整体。
2、数据库事务的四个特性(ACID)
A:原子性,事务中的所有操作作为一个整体不可分割,要么全部操作要么全部不操作。
C:一致性,事务的执行结果必须使数据库从一个一致性状态转为另一个一致性状态。一致性状态:1.系统状态满足数据库的完整性约束,2.系统的状态反映数据库所描述的现实世界的真实状态。
I:隔离性:并发执行的事务不会相互影响,其对数据库的影响和他们串行执行时一样。
D:持久性:事务一旦提交,对数据库的影响就是持久的。任何事务或系统故障都不会导致数据丢失。
3、什么是数据库连接泄露
数据库连接泄露指的是如果在某次使用或者某段程序中没有正确地关闭Connection、Statement和ResultSet资源,那么每次执行都会留下一些没有关闭的连接,这些连接失去了引用而不能得到重新使用,因此就造成了数据库连接的泄漏。数据库连接的资源是宝贵而且是有限的,如果在某段使用频率很高的代码中出现这种泄漏,那么数据库连接资源将被耗尽,影响系统的正常运转。

4、聚集索引
数据行的物理顺序与列值的顺序相同,如果我们查询id比较靠后的数据,那么这行数据的地址在磁盘中的物理地址也会比较靠后。而且由于物理排列方式与聚集索引的顺序相同,所以也就只能建立一个聚集索引了。
5、主键与外键
关系型数据库中的一条记录中有若干个属性,若其中某一个属性组(注意是组)能唯一标识一条记录,该属性组就可以成为一个主键。
外键用于与另一张表的关联。是能确定另一张表记录的字段,用于保持数据的一致性。比如,A表中的一个字段,是B表的主键,那他就可以是A表的外键。
最新文章
热门文章
推荐阅读