数据库引擎常见的面试题(面试总结)

1. 什么是数据库引擎

数据库引擎:用于存储、处理、保护数据的核心服务。
当你访问数据库时,不管是手工访问,还是程序访问,都不是直接读写数据库文件,而是通过数据库引擎去访问数据库文件

2. 数据库引擎有几种

Innodb 、 MyISAM 、MEMORY 、MERGE

3.MyISAM和InnoDB的区别

  1. InnoDB支持事务,MyISAM不支持,对于InnoDB每一条SQL语言都默认封装成事务,自动提交,这样会影响速度,所以最好把多条SQL语言放在begin和commit之间,组成一个事务;
  2. InnoDB支持外键,而MyISAM不支持。对一个包含外键的InnoDB表转为MYISAM会失败;
  3. InnoDB不保存表的具体行数,执行select count(*) from table时需要全表扫描。而MyISAM用一个变量保存了整个表的行数,执行上述语句时只需要读出该变量即可,速度很快;
  4. Innodb不支持全文索引,而MyISAM支持全文索引,查询效率上MyISAM要高;
  5. 锁机制不同: InnoDB 为行级锁,myisam 为表级锁。
    数据库引擎常见的面试题(面试总结)_第1张图片

4.数据库引擎你用的那种

我用的InnoDB

5. 谈一谈你对MySQL InnoDB的认识

特点是:
1、具有较好的事务支持:支持4个事务隔离级别,支持多版本读
2、行级锁定:通过索引实现,全表扫描仍然会是表锁,注意间隙锁的影响
3、读写阻塞与事务隔离级别相关
4、具有非常高效的缓存特性:能缓存索引,也能缓存数据
5、整个表和主键以Cluster方式存储,组成一颗平衡树
6、所有Secondary Index都会保存主键信息
适用场景:
1、需要事务支持(具有较好的事务特性)
2、行级锁定对高并发有很好的适应能力,但需要确保查询是通过索引完成
3、数据更新较为频繁的场景
4、数据一致性要求较高
5、硬件设备内存较大,可以利用InnoDB较好的缓存能力来提高内存利用率,尽可能减少磁盘IO

6. 如何查看服务器有哪些存储引擎

在mysql客户端中,使用show engines命令可以查看MySQL支持的引擎

7.如何查看数据库当前使用的存储引擎(默认引擎)

在mysql客户端中,使用show variables like '%storage_engine%'命令查看
也可以在MySQL的配置文件中查看。(windows - my.ini Linux - my.cnf)

8. 如何查看数据库表所用的存储引擎

在mysql客户端中,使用show create table table_name命令查看数据库表所用的存储引擎

9. 如何创建表指定存储引擎

在mysql客户端中,使用create table table_name (column_name column_type) engine = engine_name命令创建指定存储引擎

10. 如何修改表的存储引擎

在mysql客户端中,使用alter table table_name engine=engine_name命令修改表的存储引擎

11. 如何修改默认的存储引擎

在MySQL配置文件中修改内容:default-storage-engine=INNODB

12. 如何选择合适的存储引擎

  1. 是否需要支持事务;
  2. 是否需要使用热备;
  3. 崩溃恢复,能否接受崩溃;
  4. 是否需要外键支持。
  5. 对于实际工作,选择合适的存储引擎,据具体情况而定,结合实际项目实例进行应用,才是最好的方式。

你可能感兴趣的:(面试宝典,数据库,Mysql)