2021最新大厂面试题,来看大佬都是如何

进了互联网公司,整天也就是搬砖,等到了面试的时候,发现数据库方面,忘得一塌糊涂,抽时间整理了一些数据库方面的题。

事务四大特性(ACID)原子性、一致性、隔离性、持久性?

事务的并发?事务隔离级别,每个级别会引发什么问题,MySQL默认是哪个级别?

MySQL常见的三种存储引擎(InnoDB、MyISAM、MEMORY)的区别?

MySQL的MyISAM与InnoDB两种存储引擎在,事务、锁级别,各自的适用场景?

查询语句不同元素(where、jion、limit、groupby、having等等)执行先后顺序?

什么是临时表,临时表什么时候删除?

MySQLB+Tree索引和Hash索引的区别?

聚集索引和非聚集索引区别?

有哪些锁(乐观锁悲观锁),select时怎么加排它锁?

非关系型数据库和关系型数据库区别,优势比较?

数据库三范式,根据某个场景设计数据表?

数据库的读写分离、主从复制,主从复制分析的7个问题?

使用explain优化sql和索引?

MySQL慢查询怎么解决?

什么是内连接、外连接、交叉连接、笛卡尔积等?

mysql都有什么锁,死锁判定原理和具体场景,死锁怎么解决?

varchar和char的使用场景?

mysql高并发环境解决方案?

数据库崩溃时事务的恢复机制(REDO日志和UNDO日志)?

事务的并发?事务隔离级别,每个级别会引发什么问题,MySQL默认是哪个级别?从理论上来说,事务应该彼此完全隔离,以避免并发事务所导致的问题,然而,那样会对性能产生极大的影响,因为事务必须按顺序运行,在实际开发中,为了提升性能,事务会以较低的隔离级别运行,事务的隔离级别可以通过隔离事务属性指定。

事务的并发问题

1、脏读:事务A读取了事务B更新的数据,然后B回滚操作,那么A读取到的数据是脏数据

2、不可重复读:事务A多次读取同一数据,事务B在事务A多次读取的过程中,对数据作了更新并提交,导致事务A多次读取同一数据时,结果因此本事务先后两次读到的数据结果会不一致。

3、幻读:幻读解决了不重复读,保证了同一个事务里,查询的结果都是事务开始时的状态(一致性)。

例如:事务T1对一个表中所有的行的某个数据项做了从“1”修改为“2”的操作这时事务T2又对这个表中插入了一行数据项,而这个数据项的数值还是为“1”并且提交给数据库。而操作事务T1的用户如果再查看刚刚修改的数据,会发现还有跟没有修改一样,其实这行是从事务T2中添加的,就好像产生幻觉一样,这就是发生了幻读。

事务处理上方面

MyISAM:强调的是性能,每次查询具有原子性,其执行数度比InnoDB类型更快,但是不提供事务支持。

InnoDB:提供事务支持事务,外部键等高级数据库功能。具有事务(


转载请注明:http://www.aierlanlan.com/grrz/2429.html

  • 上一篇文章:
  •   
  • 下一篇文章: 没有了