当前位置:   article > 正文

MySQL的面试题讲解看完肯定对你有帮助!!(精选24道)_mysql面试题

mysql面试题

一、理论方面

1.InnoDB存储引擎和MyISAM的区别

InnoDB和MyISAM是MySQL数据库常见的两种存储引擎,它们在功能和性能方面有一些重要区别:

        1.事务支持:InnoDB是一个支持事务处理的存储引擎,它使用了ACID(原子性、一致性、隔离性和持久性)特性来确保数据的完整性。而MyISAM不支持事务,它执行的是自动提交模式,即每个SQL语句都被视为一个独立的事务。

        2.锁定粒度:InnoDB使用行级锁定(row-level locking),这意味着在并发操作时只锁定所需的行,从而提高了多用户并发处理的效率。MyISAM使用表级锁定(table-level locking),当一个用户在对某个表执行写操作时,其他用户不能同时对该表进行写操作,这可能导致并发性能下降。

        3.外键支持:InnoDB支持外键约束,可以确保关联表之间的数据完整性。MyISAM不支持外键约束,只能通过应用程序层面来维护数据一致性。

        4.崩溃恢复:InnoDB具有崩溃恢复能力,它会在数据库发生异常崩溃时恢复数据的一致性。MyISAM在崩溃发生时不提供数据恢复功能,可能导致数据损坏或不一致。

        5.全文索引:MyISAM支持全文索引,可以进行高效的全文搜索。而InnoDB在MySQL 5.6版本之前不支持全文索引,但在之后的版本中添加了全文搜索功能。

总体上说,如果你需要事务支持、并发性能较好、数据一致性要求较高或需要使用外键约束,那么选用InnoDB存储引擎会更合适。而如果你对并发性能要求不高、只需简单的读写操作并且对数据一致性要求不高,那么使用MyISAM存储引擎可能会更简单和高效。但是需要注意的是,根据具体的应用场景和需求,选择正确的存储引擎是非常重要的。

2.DELETE、DROP、TRUNCATE三者的区别

DELETE、DROP和TRUNCATE是SQL语句中用于删除数据和对象的操作,它们之间有一些重要的区别:

        1.DELETEDELETE语句用于从表中删除满足条件的数据行。它是一个事务操作,可以使用WHERE子句指定删除的条件。DELETE语句执行会触发表上的触发器,并且可以配合使用ROLLBACK命令撤销删除操作。DELETE语句只删除表中的数据,而不会删除表本身。

         2.DROPDROP语句用于删除数据库对象,可以是表、索引、视图、存储过程等。DROP TABLE语句可以删除整个表及其相关的索引、触发器、约束等。DROP语句是一个DDL(数据定义语言)操作,它会立即删除对象,且无法恢复。DROP语句一般不回滚,一旦执行成功,相关对象将永久删除。

        3.TRUNCATETRUNCATE语句用于从表中删除所有数据,但保留表的结构。它是一个DDL操作,比DELETE更快,因为它仅仅是删除数据页的引用,而不是逐行删除数据。TRUNCATE语句不会触发表上的触发器,也无法撤销。TRUNCATE语句在执行成功后,表的计数器会被重置,自动增量插入的计数器也会被重置

总结起来,DELETE用于删除表中的特定行数据,DROP用于删除数据库对象,TRUNCATE用于删除表中的所有数据。DELETE是一个DML(数据操作语言)操作,DROP和TRUNCATE是DDL操作。DELETE语句可以撤销,而DROP和TRUNCATE删除的数据或对象无法恢复。根据需要选择合适的语句来执行删除操作。

3.行转列的使用

行转列是一种重塑或重新组织数据的操作,将原先以行的形式存储的数据转换为以列的形式存储。行转列的技术可以使用在各种领域,如数据分析、报表生成等。

举个例子:

科目/学员001002003....
科目一908999...
科目二900100...
从上面这样变成下面这样
学员/科目科目一科目二
0019090
002890
00399100
.........
后面的方式是不是更为简便,这就是“行转列”。
那么在MySQL是怎么使用的呢?我们一起来看看
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/酷酷是懒虫/article/detail/740035
推荐阅读
相关标签