- 数据库常见面试题 推荐度:
- 相关推荐
数据库常见面试题
在平时的学习、工作中,我们都离不开试题,试题可以帮助参考者清楚地认识自己的知识掌握程度。什么样的试题才能有效帮助到我们呢?以下是小编收集整理的数据库常见面试题,欢迎大家借鉴与参考,希望对大家有所帮助。

1、说出数据连接池的工作机制是什么
J2EE 服务器启动时会建立一定数量的池连接,并一直维持不少于此数目的池连接。客户端程序需要连接时,池驱动程序会返回一个未使用的池连接并将其表记为忙。如果当前没有空闲连接,池驱动程序就新建一定数量的连接,新建连接的数量有配置参数决定。当使用的池连接调用完成后,池驱动程序将此连接表记为空闲,其他调用就可以使用这个连接。
2、存储过程和函数的区别
存储过程是用户定义的一系列sql语句的集合,涉及特定表或其它对象的任务,用户可以调用存储过程,而函数通常是数据库已定义的方法,它接收参数并返回某种类型的值并且不涉及特定用户表。
3、事务是什么?
事务是作为一个逻辑单元执行的一系列操作,一个逻辑工作单元必须有四个属性,称为 ACID(原子性、一致性、隔离性和持久性)属性,只有这样才能成为一个事务:
原子性:
事务必须是原子工作单元;对于其数据修改,要么全都执行,要么全都不执行。
一致性:
事务在完成时,必须使所有的数据都保持一致状态。在相关数据库中,所有规则都必须应用于事务的修改,以保持所有数据的完整性。事务结束时,所有的内部数据结构(如 B 树索引或双向链表)都必须是正确的。
隔离性:
由 并发事务所作的修改必须与任何其它并发事务所作的修改隔离。事务查看数据时数据所处的状态,要么是另一并发事务修改它之前的状态,要么是另一事务修改它之 后的状态,事务不会查看中间状态的数据。这称为可串行性,因为它能够重新装载起始数据,并且重播一系列事务,以使数据结束时的状态与原始事务执行的状态相 同。
持久性
事务完成之后,它对于系统的影响是永久性的。该修改即使出现系统故障也将一直保持。
4、游标的作用?如何知道游标已经到了最后?
游标用于定位结果集的行,通过判断全局变量@@FETCH_STATUS可以判断是否到了最后,通常此变量不等于0表示出错或到了最后
5、触发器分为事前触发和事后触发,这两种触发有和区别。语句级触发和行级触发有何区别?
事前触发器运行于触发事件发生之前,而事后触发器运行于触发事件发生之后。通常事前触发器可以获取事件之前和新的字段值。
语句级触发器可以在语句执行前或后执行,而行级触发在触发器所影响的每一行触发一次
数据库面试题
一、基础概念
请简要描述MySQL的架构。
MySQL采用客户端/服务器架构,客户端通过网络发送请求到服务器,服务器执行请求并返回结果。
什么是数据库范式?
数据库范式是数据库设计中的规范,用来减少数据冗余和提高数据一致性。常用的范式有:第一范式(1NF)、第二范式(2NF)、第三范式(3NF)。
请解释一下MySQL的事务特性。
MySQL事务具有以下特性:原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)、持久性(Durability),简称ACID特性。
二、存储引擎
请介绍MySQL常用的存储引擎及其特点。
MySQL常用的存储引擎有:InnoDB、MyISAM、MEMORY、MERGE、NDB等。
InnoDB:支持事务、行级锁定、外键、支持高并发。
MyISAM:不支持事务、表级锁定、不支持外键,读写性能较高。
MEMORY:数据存储在内存中,适用于缓存数据。
MERGE:将多个MyISAM表合并成一个表。
NDB:集群存储引擎,适用于分布式数据库。
请说明InnoDB和MyISAM的区别。
事务支持:InnoDB支持事务,MyISAM不支持。
锁定机制:InnoDB支持行级锁定,MyISAM支持表级锁定。
外键支持:InnoDB支持外键,MyISAM不支持。
数据恢复:InnoDB支持崩溃恢复,MyISAM不支持。
读写性能:MyISAM在读写性能方面略胜一筹。
三、事务
什么是事务?
事务是一系列操作的集合,这些操作要么全部执行,要么全部不执行。
请解释ACID特性在事务中的作用。
原子性:保证事务中的所有操作要么全部完成,要么全部不做。
一致性:保证事务执行后,数据库状态保持一致。
隔离性:防止多个事务同时操作同一数据时产生冲突。
持久性:保证事务提交后,其结果永久保存。
请说明事务隔离级别。
事务隔离级别有:读未提交(Read Uncommitted)、读已提交(Read Committed)、可重复读(Repeatable Read)、串行化(Serializable)。
四、锁
什么是锁?
锁是数据库系统用于控制并发访问的一种机制,可以防止多个事务同时修改同一数据。
请解释表级锁和行级锁的区别。
表级锁:锁定整个表,影响其他事务对该表的访问。
行级锁:锁定表中的一行,不影响其他事务对该行的访问。
请说明共享锁和排他锁的区别。
共享锁:允许多个事务同时读取同一数据。
排他锁:只允许一个事务对数据进行修改。
五、索引
什么是索引?
索引是数据库表中的一种数据结构,可以提高查询效率。
请解释B树索引的概念及其优点。
B树索引是一种多路平衡查找树,具有以下优点:
平衡性:保证查询效率。
磁盘友好:减少磁盘I/O操作。
范围查询效率:支持范围查询。
请说明最左前缀原则。
最左前缀原则是指在联合索引中,查询条件必须从最左边的列开始,才能利用索引。
六、性能优化
如何提高MySQL查询效率?
优化SQL语句:避免全表扫描、减少子查询、使用索引等。
优化数据库设计:遵循范式设计、减少数据冗余、合理使用外键等。
优化服务器配置:调整缓冲区大小、线程数等。
请解释读写分离和分库分表的概念。
读写分离:将读操作和写操作分配到不同的服务器上,提高系统并发能力。
分库分表:将数据分散到多个数据库或表中,提高系统扩展性。
【数据库常见面试题】相关文章:
数据库常见面试题08-23
数据库面试题及答案10-26
最新数据库面试题06-01
常见的英语面试题09-17
常见的算法面试题08-03
常见银行面试题08-19
常见银行面试题10-30
常见银行面试题10-31
数据库面试题:存储过程09-07