数据库 常见笔试面试题

  • 事务 及 事务特性:
    事务:事务(Transaction)是并发控制的基本单位。所谓的事务,它是一个操作序列,这些操作要么都执行,要么都不执行,它是一个不可分割的工作单位。
    一个需要事务的常见例子:转账操作可以分为两部分来完成,转入和转出。只有这两部分都完成了才可以认为是转账成功。在数据库中,这个过程是使用两条语句来完成的,如果其中任意一条语句出现了异常没有执行,则会导致两个账号的金额不同步,造成错误。
    事务特性:
    ①原子性(Atomicity):
    原子性是指事务包含的所有操作要么全部成功,要么全部失败回滚,因此事务的操作如果成功就必须要完全应用到数据库,如果操作失败则不能对数据库有任何影响。
    ②一致性(Consistency):一致性是指事务必须使数据库从一个一致性状态变换到另一个一致性状态,也就是说一个事务执行之前和执行之后都必须处于一致性状态。或者说只有合法的数据可以被写入数据库,否则事务应该将其回滚到最初状态。事务的运行并不改变数据的一致性。例如,完整性约束了a+b=10,一个事务改变了a,那么b也应该随之改变。
    ③隔离性(Isolation):事务允许多个用户对同一个数据进行并发访问,而不破坏数据的正确性和完整性。同时,并行事务的修改必须与其他并行事务的修改相互独立。
    当不同的事务同时操纵相同的数据时,每个事务都有各自的完整数据空间。由并发事务所做的修改必须与任何其他并发事务所做的修改隔离。事务查看数据更新时,数据所处的状态要么是另一事务修改它之前的状态,要么是另一事务修改它之后的状态,事务不会查看到中间状态的数据。
    ④持久性(Durability):持久性是指一个事务一旦被提交了,那么对数据库中的数据的改变就是永久性的,即便是在数据库系统遇到故障的情况下也不会丢失提交事务的操作。
  • 事务的四种隔离级别:由低到高依次为Read uncommitted、Read committed、Repeatable read、Serializable,这四个级别可以逐个解决脏读、不可重复读、幻读这几类问题。

    ①可读取未确认(Read uncommitted):
    写事务阻止其他写事务,避免了更新遗失。但是没有阻止其他读事务。 
    存在的问题:脏读。即读取到不正确的数据,因为另一个事务可能还没提交最终数据,这个读事务就读取了中途的数据,这个数据可能是不正确的。 
    解决办法就是下面的“可读取确认”。

    ②可读取确认(Read committed):
    写事务会阻止其他读写事务读事务不会阻止其他任何事务。 
    存在的问题:不可重复读。即在一次事务之间,进行了两次读取,但是结果不一样,可能第一次id为1的人叫“李三”,第二次读id为1的人就叫了“李四”。因为读取操作不会阻止其他事务。 
    解决办法就是下面的“可重复读”。

    ③可重复读(Repeatable read):
    读事务会阻止其他写事务,但是不会阻止其他读事务。 
    存在的问题:幻读。可重复读阻止的写事务包括update和delete(只给存在的表加上了锁),但是不包括insert(新行不存在,所以没有办法加锁),所以一个事务第一次读取可能读取到了10条记录,但是第二次可能读取到11条,这就是幻读。 
    解决办法就是下面的“串行化”。

    ④可串行化(Serializable):
    读加共享锁,写加排他锁。这样读取事务可以并发,但是读写,写写事务之间都是互斥的,基本上就是一个个执行事务,所以叫串行化。
  • MySQL两种引擎区别:InnoDB和MyISAM
    ①InnoDB:

    a. 支持ACID的事务,支持事务的四种隔离级别。
    b. 支持行级锁及外键约束:因此可以支持写并发。
    c. 不存储总行数。
    d. 一个InnoDb引擎存储在一个文件空间,也有可能为多个,受操作系统文件大小的限制。
    e. 主键索引采用聚集索引(索引的数据域存储数据文件本身),辅索引的数据域存储主键的值;因此从辅索引查找数据,需要先通过辅索引找到主键值,再访问辅索引;最好使用自增主键,防止插入数据时,为维持B+树结构,文件的大调整。

    ②MyISAM:
    a. 不支持事务,但是每次查询都是原子的。
    b. 支持表级锁,即每次操作是对整个表加锁。
    c. 存储表的总行数。
    d. 一个MYISAM表有三个文件:索引文件、表结构文件、数据文件。
    e. 采用非聚集索引,索引文件的数据域存储指向数据文件的指针。辅索引与主索引基本一致,但是辅索引不用保证唯一性。

    ③其他:
    MyIASM管理非事务表,提供高速存储和检索以及全文搜索能力,如果再应用中执行大量select操作,应该选择MyIASM
    InnoDB用于事务处理,具有ACID事务支持等特性,如果在应用中执行大量insert和update操作,应该选择InnoDB

    ④InnoDB和MyISAM索引区别:
    a. 主索引的区别,InnoDB的数据文件本身就是索引文件。而MyISAM的索引和数据是分开的。 
    b. 辅助索引的区别:InnoDB的辅助索引data域存储相应记录主键的值而不是地址。而MyISAM的辅助索引和主索引没有多大区别。

猜你喜欢

转载自blog.csdn.net/weixin_39731083/article/details/82079541