当前位置: 移动技术网 > IT编程>数据库>Mysql > 关于mysql 高频面试题整理

关于mysql 高频面试题整理

2020年07月14日  | 移动技术网IT编程  | 我要评论

MySQL引擎 InnoDB和MyISAM的区别
1、MySQL默认采用的是MyISAM。
2、MyISAM不支持事务,而InnoDB支持。
3、InnoDB支持数据行锁定,MyISAM不支持行锁定,只支持锁定整个表。
4、InnoDB支持外键,MyISAM不支持。
5、InnoDB的主键范围更大,最大是MyISAM的2倍。
6、InnoDB不支持全文索引,而MyISAM支持。全文索引是指对char、varchar和text中的每个词(停用词除外)建立倒排序索引。MyISAM的全文索引其实没啥用,因为它不支持中文分词,必须由使用者分词后加入空格再写到数据表里,而且少于4个汉字的词会和停用词一样被忽略掉。
7、MyISAM支持GIS数据,InnoDB不支持。
MyISAM 和 INNODB的区别

  1. 事务安全(MyISAM不支持事务,INNODB支持事务)
  2. 查询和添加速度(MyISAM批量插入速度快)
  3. 支持全文索引(MyISAM支持全文索引,INNODB不支持全文索引)
  4. 锁机制(MyISAM时表锁,innodb是行锁)
  5. 外键 MyISAM 不支持外键, INNODB支持外键. (在PHP开发中,通常不设置外键,通常是在程序中保证数据的一致)

如何优化 mysql存储引擎,
1.1.1 MyISAM
MyISAM引擎是MySQL 5.1及之前版本的默认引擎,它的特点是:
不支持行锁,读取时对需要读到的所有表加锁,写入时则对表加排它锁;
不支持事务;
不支持外键;
不支持崩溃后的安全恢复;
在表有读取查询的同时,支持往表中插入新纪录;
支持BLOB和TEXT的前500个字符索引,支持全文索引;
支持延迟更新索引,极大提升写入性能;
对于不会进行修改的表,支持压缩表,极大减少磁盘空间占用。

InnoDB在MySQL 5.5后成为默认索引,它的特点是:
支持行锁,采用MVCC来支持高并发;
支持事务;
支持外键;
支持崩溃后的安全恢复;
不支持全文索引。
myISAM 与 InnoDB 主要区别

myisam 批量插入速度快,InnoDB慢,myisam插入数据时不排序
InooDB支持事务,而MyISAM不支持事务;
InnoDB不支持全文索引,myisam支持全文索引
锁机制,myisam是表锁,InnoDB是行锁
myisam不支持外键,InnoDB支持外键
InnoDB支持MVCC,而MyISAM不支持;
InnoDB是索引组织表, myisam 是堆表;
InnoDB表支持多种行格式, myisam 不支持;
InnoDB不能通过直接拷贝表文件的方法拷贝表到另外一台机器, myisam 支持;

索引用什么数据结构,为什么用b+而不是红黑树,或者B树,或者哈希
B+树能显著减少IO次数,提高效率
B+树的查询效率更加稳定,因为数据放在叶子节点
B+树能提高范围查询的效率,因为叶子节点指向下一个叶子节点
B+tree 数据只存储在叶子节点中。这样在B树的基础上每个节点存储的关键字数更多,树的层级更少所以查询数据

事务特性
事务特性(4种)

原子性 (atomicity):强调事务的不可分割.
一致性 (consistency):事务的执行的前后数据的完整性保持一致.
隔离性 (isolation):一个事务执行的过程中,不应该受到其他事务的干扰
持久性(durability) :事务一旦结束,数据就持久到数据库

隔离级别

在这里插入图片描述

脏读,不可重复读,幻读,解释
事务的并发问题

1、脏读:读取了未提交的新事物,然后被回滚了

2、不可重复读:事不可重复读是指在对于数据库中的某个数据,一个事务范围内多次查询却返回了不同的数据值,这是由于在查询间隔,被另一个事务修改并提交了。
  3、幻读: 在事务A多次读取构成中,事务B对数据进行了新增操作,导致事务A多次读取的数据不一致。幻读和不可重复读的区别在于,
不可重复是针对记录的update操作,只要在记录上加写锁,就可避免;幻读是对记录的insert操作,

要禁止幻读必须加上全局的写锁(比如在表上加写锁)。 另外说一下两类丢失更新:
解决,如果一个事物加上表级锁,只要有任何东西操作这个表的时候,禁止任何操作的并发

小结:不可重复读的和幻读很容易混淆,不可重复读侧重于修改,幻读侧重于新增或删除。解决不可重复读的问题只需锁住满足条件的行,解决幻读需要锁表

事务隔离级别的作用 为什么要采用B+树,而不是红黑树,或者B树,或者哈希

在这里插入图片描述

本文地址:https://blog.csdn.net/zhangqiang180/article/details/107300076

如对本文有疑问, 点击进行留言回复!!

相关文章:

  • mysql解决时区相关问题

    前言:在使用 mysql 的过程中,你可能会遇到时区相关问题,比如说时间显示错误、时区不是东八区、程序取得的时间和数据库存储的时间不一致等等问题。其实,这些问题... [阅读全文]
  • MySQL8.0内存相关参数总结

    mysql理论上使用的内存 = 全局共享内存 + max_connections×线程独享内存。也就是:innodb_buffer_pool_size + in... [阅读全文]
  • mysql如何查询日期与时间

    前言: 在项目开发中,一些业务表字段经常使用日期和时间类型,而且后续还会牵涉到这类字段的查询。关于日期及时间的查询等各类需求也很多,本篇文章简单讲讲日期及时间字... [阅读全文]
  • 深入了解mysql长事务

    前言: 本篇文章主要介绍mysql长事务相关内容,比如说我们开启的一个事务,一直没提交或回滚会怎样呢,出现事务等待情况应该如何处理,本篇文章将给你答案。注意:本... [阅读全文]
  • 详解mysql DML语句的使用

    前言: 在上篇文章中,主要为大家介绍的是ddl语句的用法,可能细心的同学已经发现了。本篇文章将主要聚焦于dml语句,为大家讲解表数据相关操作。这里说明下ddl与... [阅读全文]
  • JDBC怎么连接数据库

    JDBC的快速入门(写这个东西是为了自己记一个笔记,或者为了方便别人应付作业)你要连接什么数据库就要下载什么类型... [阅读全文]
  • 高性能Mysql的逻辑架构和常见的存储引擎

    高性能Mysql的逻辑架构和常见的存储引擎

    前言: 为了充分发挥MySQL的性能并顺利地使用,就必须理解其设计。MySQL的灵活性体现在很多方面。例如,... [阅读全文]
  • 如何选择合适的MySQL日期时间类型来存储你的时间

    构建数据库写程序避免不了使用日期和时间,对于数据库来说,有多种日期时间字段可供选择,如 timestamp 和 datetime 以及使用 int 来存储 un... [阅读全文]
  • MySQL数据库使用规范总结

    导读: 关于mysql数据库规范,相信大家多少看过一些文档。本篇文章给大家详细分类总结了数据库相关规范,从库表命名设计规范讲起,到索引设计规范,后面又给出sql... [阅读全文]
  • 详解MySQL 外键约束

    官方文档:1.外键作用:mysql通过外键约束来保证表与表之间的数据的完整性和准确性。2.外键的使用条件 两个表必须是innodb表,myisam表暂时不支持... [阅读全文]
验证码:
移动技术网