数据库面试(DBMS面试题和答案合集)

数据库面试(DBMS面试题和答案合集)

文章图片
下面列出了最常见的DBMS面试问题和答案。
1)什么是DBMS?
DBMS是程序的集合, 可帮助用户创建和维护数据库。换句话说, DBMS为我们提供了用于执行不同操作(例如创建数据库, 将数据插入其中, 从中删除数据, 更新数据等)的界面或工具。DBMS是一种将数据存储在数据库中的软件。与基于文件的系统相比, 这种方法更加安全。使用DBMS, 我们可以克服许多问题, 例如-数据冗余, 数据不一致, 易于访问, 更有条理和易于理解等。有一些流行的数据库管理系统的名称-MySQL, Oracle, SQL Server, Amazon简单DB(基于云)等。
下图定义了DBMS的工作。
数据库面试(DBMS面试题和答案合集)

文章图片
2)什么是数据库?
数据库是一个逻辑, 一致且有条理的数据集合, 可以轻松地对其进行访问, 管理和更新。数据库, 也称为电子数据库, 其结构旨在有效地提供创建, 插入, 更新数据的功能, 并以文件或文件集的形式存储在磁盘, 磁带和另一类辅助设备上。数据库主要由对象(表)组成, 而表包括记录和字段。字段是数据存储的基本单位, 其中包含有关数据库描述的实体的特定方面或属性的信息。 DBMS用于以查询的形式从数据库中提取数据。
欲了解更多信息, 请点击此处
3)什么是数据库系统?
数据库和DBMS软件的集合一起称为数据库系统。通过数据库系统, 我们可以执行许多活动, 例如-
数据可以轻松存储在数据库中, 并且没有数据冗余和数据不一致的问题。
必要时, 将使用DBMS软件从数据库中提取数据。因此, 数据库和DBMS软件的结合使人们能够以适当的准确性和安全性来存储, 检索和访问数据。
4)DBMS有哪些优势?
  • 冗余控制
  • 限制未经授权的访问
  • 提供多个用户界面
  • 提供备份和恢复
  • 加强完整性约束
  • 确保数据一致性
  • 易于访问
  • 由于使用查询, 易于进行数据提取和数据处理
欲了解更多信息, 请点击此处
5)什么是DBMS中的检查点?
Checkpoint是一种机制, 其中所有以前的日志都从系统中删除并永久存储在存储磁盘中。
有两种方法可以帮助DBMS恢复和维护ACID属性, 它们是维护每个事务的日志和维护影子页面。因此, 在基于日志的恢复系统上, 检查点已经存在。检查点是数据库引擎在崩溃后可以恢复到的那些点, 它是指定的最小点, 从该点可以使用事务日志记录恢复所有提交的数据, 直到崩溃点为止。
6)DBMS何时出现检查点?
检查点就像是DBMS状态的快照。使用检查点, DBMS可以减少重新启动期间发生后续崩溃时要完成的工作量。系统崩溃后, 检查点用于恢复数据库。在基于日志的恢复系统中使用检查点。当由于系统崩溃而需要重新启动系统时, 那时候我们将使用检查点。因此, 我们不必从一开始就执行交易。
7)透明DBMS是什么意思?
透明DBMS是一种DBMS, 它的物理结构对用户隐藏。物理结构或物理存储结构对DBMS的内存管理器来说是隐含的, 它描述了如何将数据存储在磁盘上。
8)关系代数中的一元运算是什么?
投影和选择是关系代数中的一元运算。一元运算是使用单个操作数的运算。一元运算是SELECTION, PROJECTION和RENAME。
与SELECTION中一样, 例如使用关系运算符-=, < =, > =等。
9)什么是RDBMS?
RDBMS代表关系数据库管理系统。它用于维护表中的数据记录和索引。 RDBMS是DBMS的一种形式, 它使用该结构来识别和访问与数据库中其他数据有关的数据。 RDBMS是使你能够以最小的难度执行各种操作(例如-更新, 插入, 删除, 操作和管理关系数据库)的系统。大多数时候, RDBMS使用SQL语言, 因为它易于理解并且经常使用。
10)有几种类型的数据库语言?
有四种类型的数据库语言:
  • 数据定义语言(DDL), 例如CREATE, ALTER, DROP, TRUNCATE, RENAME等。所有这些命令用于更新数据, 这就是为什么它们被称为数据定义语言。
  • 数据操作语言(DML), 例如SELECT, UPDATE, INSERT, DELETE等。这些命令用于操作已更新的数据, 这就是它们成为数据操作语言的一部分的原因。
  • 数据控制语言(DCL), 例如GRANT和REVOKE。这些命令用于授予和删除用户对数据库的访问权限。因此, 它们是数据控制语言的一部分。
  • 事务控制语言(TCL), 例如COMMIT, ROLLBACK和SAVEPOINT。这些是用于管理数据库中事务的命令。 TCL用于管理DML所做的更改。
数据库语言意味着用于更新, 修改和处理数据的查询。
11)你对数据模型了解什么?
数据模型被指定为用于描述数据, 数据关系, 数据语义和约束的概念性工具的集合。这些模型用于描述实体及其属性之间的关系。
有许多数据模型:
  • 分层数据模型
  • 网络模型
  • 关系模型
  • 实体关系模型等。
12)定义一个关系模式和一个关系。
关系模式被指定为一组属性。也称为表架构。它定义了表的名称。关系模式被称为蓝图, 借助该蓝图, 我们可以解释如何将数据组织到表中。该蓝图不包含任何数据。
关系被指定为一组元组。关系是具有识别关键属性的一组相关属性
请参阅以下示例:
令r为包含集合元组(t1, t2, t3, … , tn)的关系。每个元组是n值t =(v1, v2, … ., vn)的有序列表。
13)什么是关联度?
关系度是其关系模式的许多属性。关系度也称为基数, 它定义为一个实体的出现次数, 该数量与另一实体的出现次数相关。存在三种关系度, 它们是一对一(1:1), 一对多(1:M), 多对一(M:M)。
14)什么是关系?
该关系定义为两个或多个实体之间的关联。 DBMS中存在三种类型的关系-
一对一:任何对象的一条记录都可以与另一对象的一条记录相关。
一对多(多对一):在这里, 任何对象的一条记录可以与其他对象的许多记录相关, 反之亦然。
多对多:此处, 一个对象的多个记录可以与另一个对象的n个记录相关。
15)文件处理系统有哪些缺点?
  • 前后不一致
  • 不安全
  • 数据冗余
  • 难以访问数据
  • 资料隔离
  • 数据的完整性
  • 不能同时访问
  • 有限的数据共享
  • 原子性问题
16)什么是DBMS中的数据抽象?
DBMS中的数据抽象是向用户隐藏无关详细信息的过程。由于数据库系统由复杂的数据结构组成, 因此它使用户与数据库的交互变得可访问。
例如:我们知道大多数用户都喜欢那些具有简单GUI(意味着没有复杂处理)的系统。因此, 为了使用户保持调优并简化对数据的访问, 有必要进行数据抽象。除此以外, 数据抽象将系统划分为不同的层次, 以使工作得以指定和明确定义。
17)数据抽象的三个层次是什么?
以下是数据抽象的三个级别:
物理级别:这是最低的抽象级别。它描述了如何存储数据。
逻辑级别:这是下一个更高的抽象级别。它描述了哪些数据存储在数据库中以及这些数据之间的关系。
视图级别:这是数据抽象的最高级别。它仅描述整个数据库的一部分。
例如-用户使用GUI与系统进行交互并填写所需的详细信息, 但用户不知道如何使用数据。因此, VIEW LEVEL中的抽象级别完全很高。
然后, 对程序员来说是下一个级别, 因为在此级别中, 字段和记录是可见的, 并且程序员具有这一层的知识。因此, 这里的抽象级别在VIEW LEVEL中有点低。
最后, 描述存储块的物理级别。
18)什么是DDL(数据定义语言)?
数据定义语言(DDL)是命令的标准, 用于定义数据库中的不同结构。最常见的DDL语句是CREATE, ALTER和DROP。这些命令用于将数据更新到数据库中。
19)什么是DML(数据处理语言)?
DData操作语言(DML)是一种语言, 它使用户能够访问或操作由适当的数据模型组织的数据。例如-SELECT, UPDATE, INSERT, DELETE。
DML有两种类型:
程序DML或低级DML:它要求用户指定所需的数据以及如何获取这些数据。
非过程DML或高级DML:它要求用户指定所需的数据, 而不指定如何获取那些数据。
20)解释DML编译器的功能。
DML编译器以查询评估引擎可以理解的查询语言翻译DML语句。之所以需要DML编译器, 是因为DML是语法元素家族, 与其他需要编译的编程语言非常相似。因此, 必须使用查询评估引擎可以理解的语言来编译代码, 然后以适当的输出处理那些查询。
21)什么是关系代数?
关系代数是一种过程查询语言, 它包含一组将一个或两个关系作为输入并产生新关系的操作。关系代数是关系模型的基本运算集。关系代数的决定性点在于它类似于对数字进行运算的代数。
关系代数的基本运算很少:
  • 查找
  • 项目
  • 设置差异
  • 联盟
  • 重命名等
22)什么是关系演算?
关系演算是一种非过程查询语言, 它使用数学谓词演算代替代数。关系演算不适用于诸如代数, 微分, 积分等数学基础。这就是为什么它也称为谓词演算。
关系演算有两种类型:
  • 元组关系演算
  • 领域关系演算
23)通过查询优化你了解什么?
术语” 查询优化” 指定了一种有效的执行计划, 用于评估估算成本最低的查询。当存在多种方法时, 查询优化的概念就进入了框架, 并且针对同一任务存在算法, 然后出现了一个问题:哪种效率更高, 而确定有效方式的过程称为查询优化。
查询优化有很多好处:
  • 它减少了时间和空间的复杂性。
  • 由于进行了优化, 因此每个查询所需的时间相对较少, 因此可以执行更多查询。
  • 用户满意, 因为它将快速提供输出
24)DBMS的耐用性是什么意思?
一旦DBMS通知用户事务已成功完成, 即使系统在其所有更改都反映在磁盘上之前崩溃了, 事务的效果也应持续。该特性称为耐久性。持久性确保一旦将事务提交到数据库中, 它将被存储在非易失性内存中, 并且在此之后系统故障不再影响该数据。
25)什么是规范化?
规范化是根据功能关系对给定关系模式进行分析的过程。它用于最小化冗余, 还用于最小化插入, 删除和更新干扰。标准化被认为是必不可少的过程, 因为它可用于避免数据冗余, 插入异常, 更新异常, 删除异常。
最常用的范式是:
  • 第一范式(1NF)
  • 第二范式(2NF)
  • 第三范式(3NF)
  • 博伊斯与科德范式(BCNF)
26)什么是非正规化?
非规范化是提高数据库性能和添加冗余数据的过程, 该过程有助于消除复杂数据。非规范化是数据库优化技术的一部分。此过程用于避免使用复杂且昂贵的联接。归一化不是指不进行归一化, 而是归一化发生在归一化之后。在此过程中, 首先, 将使用规范化过程删除数据的冗余, 而不是通过非规范化过程, 我们将根据需要添加冗余数据, 以便我们可以轻松避免昂贵的联接。
27)什么是功能依赖?
功能依赖性是规范化的起点。当两个属性之间的关系允许你唯一地确定相应属性的值时, 它存在。功能依赖关系也称为数据库依赖关系, 并定义为当关系中的一个属性唯一确定另一个属性时发生的关系。它写为A-> B, 这意味着B在功能上依赖于A。
28)什么是E-R模型?
E-R模型是Entity-Relationship模型的简称。该模型基于真实世界。它包含必要的对象(称为实体)以及这些对象之间的关系。这里的主要对象是实体, 该实体的属性, 关系集, 该关系集的属性可以以E-R图的形式进行映射。
在E-R图中, 实体用矩形表示, 关系用菱形表示, 属性是实体的特征并用椭圆表示, 数据流用直线表示。
29)什么是实体?
实体是数据库中的一组属性。实体可以是实际存在于该世界中的现实世界对象。所有实体都有其属性, 这些属性在现实世界中被视为对象的特征。
例如:在公司的雇员数据库中, 可以将雇员, 部门和名称视为实体。这些实体具有某些特征, 这些特征将成为相应实体的属性。
30)什么是实体类型?
实体类型被指定为具有相同属性的实体集合。实体类型通常对应于数据库中的一个或几个相关表。定义或唯一标识实体的特征或特性称为实体类型。
例如, 学生以student_id, 系和课程为特征。
31)什么是实体集?
实体集指定数据库中特定实体类型的所有实体的集合。实体集称为共享相同属性的所有实体的集。
例如, 一组人, 一组学生, 一组公司等。
32)什么是实体类型的扩展?
实体类型的扩展被指定为特定实体类型的实体的集合, 这些实体被分组为一个实体集。
33)什么是弱实体集?
没有足够属性来形成主键的实体集称为弱实体集。弱实体集的成员称为从属实体。弱实体集没有主键, 但是我们需要一种方法来区分实体集中依赖于一个特定强实体集的所有那些条目。
34)什么是属性?
属性是指数据库组件。它用于描述实体的属性。可以将属性定义为实体的特征。实体可以使用属性唯一标识。属性表示数据库行中的实例。
例如:如果一个学生是表中的实体, 则年龄将是该学生的属性。
35)DBMS中的完整性规则是什么?
数据完整性是维护数据库的重要方面。因此, 通过实施一系列规则, 可以在数据库系统中强制执行数据完整性。这些完整性集合称为完整性规则。
DBMS中有两个完整性规则:
实体完整性:它指定” 主键不能具有NULL值” 。
参照完整性:它指定” 外键可以是NULL值, 也可以是其他关系的主键值
36)延伸和内涵是什么意思?
扩展名:扩展名是任何情况下表中存在的元组的数量。它随着元组的创建, 更新和销毁而改变。数据库中的实际数据经常更改。因此, 数据库在特定时间的数据称为扩展或数据库状态或快照。它是时间相关的。
强度:强度也称为数据模式, 并定义为数据库的描述, 在数据库设计过程中进行指定, 并且预期保持不变。 Intension是一个常量值, 它提供表的名称, 表的结构以及对其施加的约束。
37)什么是系统R?它的两个主要子系统中有多少个?
System R是1974年至1979年在IBM San Jose研究中心设计和开发的。 System R是SQL的第一个实现, SQL是标准的关系数据查询语言, 它也是第一个证明RDBMS可以提供??更好的事务处理性能的系统。它是一个原型, 旨在表明可以构建一个可在现实环境中使用的关系系统来解决现实问题。
以下是系统R的两个主要子系统:
  • 研究存储
  • 系统关系数据系统
38)什么是数据独立性?
数据独立性指定” 应用程序独立于数据的存储结构和访问策略” 。它使你能够在一个级别上修改模式定义, 而无需在下一个更高级别上更改模式定义。
它使你能够在一个级别中修改模式定义, 而不会影响下一个更高级别的模式定义。
数据独立有两种类型:
物理数据独立性:物理数据是存储在数据库中的数据。它是位格式。物理级别的修改不应影响逻辑级别。
例如:如果我们要操作任何不应该更改表格式的表中的数据。
逻辑数据独立性:有关数据库的数据中的逻辑数据。它基本上定义了结构。如表存储在数据库中。逻辑级别的修改不应影响视图级别。
例如:如果我们需要修改任何表格的格式, 则该修改不应影响其中的数据。
注意:逻辑数据独立性更难实现。 39)数据抽象的三个层次是什么?
以下是数据抽象的三个级别:
物理级别:这是最低的抽象级别。它描述了如何存储数据。
逻辑级别:这是下一个更高的抽象级别。它描述了哪些数据存储在数据库中以及这些数据之间的关系。
视图级别:这是数据抽象的最高级别。它仅描述整个数据库的一部分。
例如-用户使用GUI与系统进行交互并填写所需的详细信息, 但是用户不知道如何使用数据。因此, VIEW LEVEL中的抽象级别绝对很高。
然后, 对程序员来说是下一个级别, 因为在此级别中, 字段和记录是可见的, 并且程序员具有这一层的知识。因此, 这里的抽象级别在VIEW LEVEL中有点低。
最后, 描述存储块的物理级别。
40)什么是加入?
Join运算是关系代数中最有用的活动之一。它是组合来自两个或多个关系的信息的最常用方法。连接总是在相同或相关的列的基础上执行。 SQL的大多数复杂查询都涉及JOIN命令。
有以下几种类型的联接:
  • 内联接:内联接分为3类。他们是:
    • Theta加盟
    • 自然加入
    • 平等加入
  • 外连接:外连接有三种类型。他们是:
    • 左外连接
    • 右外连接
    • 完全外部联接
41)什么是1NF?
1NF是第一个范式。这是可以在数据库中实现的最简单的规范化类型。 1NF的主要目标是:
  • 每列必须具有原子(单个值)
  • 要从同一表中删除重复的列
  • 为每组相关数据创建单独的表, 并用唯一的列标识每一行
42)什么是2NF?
2NF是第二范式。如果满足以下条件, 则称该表为2NF:
  • 该表格位于1NF中, 即, 首先, 该表格必须遵循1NF的规则。
  • 每个非prime属性在功能上完全依赖于主键, 即每个non-key属性都应以这样的方式依赖于主键:如果删除了任何key元素, 那么即使non_key元素也仍将保存在其中数据库。
43)什么是3NF?
3NF代表第三范式。如果满足以下条件, 则在3NF中调用数据库:
  • 它是第二范式。
  • 没有传递函数的依赖关系。
  • 例如:X-> Z
其中
X-> Y
Y不-> X
Y-> Z所以X-> Z
44)什么是BCNF?
BCMF代表Boyce-Codd范式。它是3NF的高级版本, 因此也称为3.5NF。 BCNF比3NF严格。
满足以下条件的表符合BCNF:
  • 它在3NF中。
  • 对于每个功能依赖项X-> Y, X应该是表的超级键。这仅意味着, 如果Y是素数属性, 则X不能是非素数属性。
45)解释ACID属性
ACID属性是一些基本规则, 每个事务都必须满足这些规则以保持完整性。这些属性和规则是:
原子性:原子性通常被称为” 全有或全无规则” 。这意味着所有组件都被视为一个单元, 它们要么运行完成, 要么根本不执行。
一致性:此属性表示数据的一致性。一致性意味着在事务之前和之后数据库是一致的。
ISOLATION:此属性表明可以并发执行事务数, 而不会导致数据库状态不一致。
耐用性:此属性可确保一旦提交事务, 它将存储在非易失性内存中, 并且系统崩溃也不再影响它。
46)什么是存储过程?
存储过程是一组已创建并存储在数据库中的SQL语句。存储的过程增加了可重用性, 因为这里将代码或过程存储到系统中并一次又一次地使用, 这使工作变得容易, 花费更少的处理时间并降低了系统的复杂性。因此, 如果你有需要再次使用的代码, 则保存该代码并在需要时调用该代码。
47)DELETE命令和TRUNCATE命令有什么区别?
DELETE命令:DELETE命令用于根据我们在WHERE子句中提供的条件从表中删除行。
  • DELETE命令仅删除用WHERE子句指定的那些行。
  • 可以回退DELETE命令。
  • DELETE命令维护一个日志, 这就是为什么它很慢。
  • 在执行DELETE功能时, DELETE使用行锁。
TRUNCATE命令:TRUNCATE命令用于从表中删除所有行(完整数据)。它类似于没有WHERE子句的DELETE命令。
  • TRUNCATE命令从表中删除所有行。
  • TRUNCATE命令无法回滚。
  • TRUNCATE命令不维护日志。这就是为什么它很快。
  • 执行TRUNCATE功能时, TRUNCATE使用表日志。
48)什么是2层架构?
2层体系结构与基本客户端-服务器相同。在两层体系结构中, 客户端上的应用程序可以直接与服务器端的数据库进行通信。
数据库面试(DBMS面试题和答案合集)

文章图片
49)什么是3层架构?
3层架构包含客户端和服务器之间的另一层。 3层体系结构的引入是为了使用户易于使用, 因为它提供了GUI, 这使系统更安全并且更易于访问。在这种体系结构中, 客户端上的应用程序与服务器上的应用程序进行交互, 服务器上的应用程序进一步与数据库系统进行通信。
数据库面试(DBMS面试题和答案合集)

文章图片
50)你如何与RDBMS通信?
你必须使用结构化查询语言(SQL)与RDBMS进行通信。使用SQL查询, 我们可以将输入提供给数据库, 然后在处理查询后, 数据库将为我们提供所需的输出。
51)共享锁和排他锁有什么区别?
共享锁:读取数据项需要共享锁。在共享锁中, 许多事务可能对同一数据项持有锁。如果允许多个事务读取数据项, 则称为共享锁。
排他锁:当任何事务将要执行写操作时, 数据项上的锁就是排他锁。因为, 如果我们允许多个事务, 那么这将导致数据库中的不一致。
52)描述密钥的类型?
有以下几种类型的键:
主键:主键是表中的属性, 可以唯一标识表中的每个记录。每张桌子都是强制性的。
候选键:候选键是可以唯一标识元组的属性或属性集。可以从这些属性中选择主键。
超级键:超级键是一组可以唯一标识元组的属性。超级键是候选键的超集。
外键:外键是一个表中的主键, 与另一个表有关系。它充当表之间的交叉引用。
工作/人力资源面试问题
jQuery面试问题
Java OOP面试问题
JSP面试问题
休眠面试问题
SQL面试题
Android面试题
MySQL面试问题
面试技巧
JavaScript面试问题
Java基础面试问题
Servlet面试问题
春季面试问题
PL / SQL面试问题
Oracle面试问题
【数据库面试(DBMS面试题和答案合集)】SQL Server面试问题

    推荐阅读