Q:MySQL常用的存储引擎有哪些?

A:MyISAM及InnoDB,5.5版本后默认数据库引擎由MyISAM变为InnoDB

Q:MyISAM及InnoDB有什么区别?至少5点

A: ①.InnoDB支持事务,MyISAM不支持

  ②.InnoDB支持外键,MyISAM不支持

  ③.InnoDB支持行级锁,MyISAM支持表级锁

  ④.InnoDB不支持全文索引,MyISAM支持(5.6版本后InnoDB也支持全文索引)

  ⑤.MyISAM数据是以文件形式存储,跨平台数据转移很方便

Q:MyISAM及InnoDB两者select count(*)哪个更快,为什么?

A:MyISAM快,因为其内部维护了一个计数器,可以直接调用,而InnoDB需要扫描全表


Q:MySQL中varchar与char的区别?

A:char是定长,最多存放255个字符;varchar是变长,最大存放字符数由最大有效行(不能超过65535字节)及字符集(gbk:1字符=2字节,utf8:1字符=3字节)确定

Q:varchar(10)与char(10)有什么区别?

A:char(10)表示存储10个字符,如果少于10个则用空格补全,而varchar(10)5.0版本以下是指最多存储10个字节,5.0版本以上是指最多存储10个字符,插入多少字符则存储多少

Q:在满足长度的前提下设计字段长度是选择varchar(255)还是varchar(256)?为什么

A:选择varchar(255),因为如果字符串长度超过255,varchar需要使用两个字节存储字符串长度,小于255时只需要一个字节,可以避免不必要的消耗


Q:数据库事务隔离级别有哪几种?

A:有4种,分别是read uncommitted、read committed、repeatable read、serializable

Q:事务并发时会出现哪几种问题?

A:有3种,分别是脏读、不可重复读、幻读;脏读是指事务A读到事务B未提交的数据;不可重复读是指在事务A多次读取同一个数据,事务B在事务A多次读取过程中对数据做了更改并提交,导致事务A多次读取数据不一致;幻读是指在事务A读取某一范围内的数据,另一个事务B在这个范围内执行插入或者删除操作,事务A发现新的“幻影”行;不可重复读侧重于修改,幻读侧重于新增或删除

Q:4种隔离级别分别会出现哪些并发问题?

A:

隔离级别
脏读(Dirty Read)

不可重复读(Nonrepeatable Read)

幻读(Phantom Read)
Read Uncommitted
读取未提交内容
Read Committed
读取已提交内容
×
Repeatable Read
可重复读
× ×
Serializable
串行化
× × × 

Q:MySQL explain命令有什么作用?

A:它可以对select语句进行分析,输出select语句执行的详细信息,以便开发人员优化

Q:explain命令输出的type代表什么?有哪些取值?有什么作用?

A:type代表join类型,它是判断查询是否高效的重要依据,常用的取值有system(表中只有一条数据,特殊的const类型)、const(针对主键或唯一索引查询)、eq_ref(通常出现在多表的join查询,针对主键或唯一索引)、ref(通常出现在多表的join查询,针对非主键索引、非唯一索引或最左前缀规则索引查询)、range(使用索引范围查询)、index(全索引扫描)、all(全表扫描)。它们的性能依次下降

Q:创建联合索引(a,b,c)实际上相当于创建了几个索引?

A:相当于创建了3个索引,即(a)、(a,b)、(a,b,c)

Q:如果用字段b,c或a,c做查询条件能用到联合索引吗?为什么?

A:b、c不能,a,c能用到a列索引。因为联合索引有最左前缀的原则,InnoDB索引实现底层为b+树,是按照从左到右的顺序来建立搜索树的

参考:

1.https://segmentfault.com/a/1190000008131735#articleHeader8

2.http://blog.codinglabs.org/articles/theory-of-mysql-index.html

MySQL QA的更多相关文章

  1. 怎样知道linux是否安装了mysql

    1. 使用 [root@localhost Desktop]# rpm -qa |grep mysql (-qa查询已经安装的软件) mysql-libs-5.1.71-1.el6.x86_64 结果 ...

  2. spring整合atomikos实现分布式事务

    前言 Atomikos 是一个为Java平台提供增值服务的并且开源类事务管理器,主要用于处理跨数据库事务,比如某个指令在A库和B库都有写操作,业务上要求A库和B库的写操作要具有原子性,这时候就可以用到 ...

  3. Linux安装MySql5.7及配置(yum安装)

    Linux安装MySql5.7及配置(yum安装) [root@xld ~]# rpm -q centos-release centos-release-7-7.1908.0.el7.centos.x ...

  4. linux安装好的mysql rpm -qa |grep mysql不见

    输入: rpm -qa|grep -i mysql

  5. QA:无法为具有固定名称“MySql.Data.MySqlClient”...

    Question: 无法为具有固定名称“MySql.Data.MySqlClient”的 ADO.NET 提供程序加载在应用程序配置文件中注册的实体框架提供程序类型“MySql.Data.MySqlC ...

  6. MySQL高级知识- MySQL的架构介绍

    [TOC] 1.MySQL 简介 概述 MySQL是一个关系型数据库管理系统,由瑞典MySQL AB公司开发,目前属于Oracle公司. MySQL是一种关联数据库管理系统,将数据保存在不同的表中,而 ...

  7. Centos6.5下编译安装mysql 5.6

    一:卸载旧版本 使用下面的命令检查是否安装有MySQL Server rpm -qa | grep mysql 有的话通过下面的命令来卸载掉 rpm -e mysql //普通删除模式 rpm -e ...

  8. centos下彻底删除 和重装MYSQL

    1 删除Mysql      yum remove  mysql mysql-server mysql-libs mysql-server;       find / -name mysql 将找到的 ...

  9. Linux1 在Linux(CentOS)上安装MySql详细记录

    前记:  毕业两年了,前两天换了份工作,由以前的传统行业跳到了互联网行业.之前的公司一直在用WinServer2003+Tomcat+SqlServer/Oracle这套部署环境.对于Linux+To ...

随机推荐

  1. PhoneUtil

    package cn.fraudmetrix.octopus.horai.biz.utils; import org.springframework.util.StringUtils; import ...

  2. IE8以下浏览器设置Title的问题

    ie8不支持网页title的如下写法  $('title').text('标题');  $('title').html('标题'); 在ie8中,正确写法: document.title = &quo ...

  3. F - Set of Strings

    You are given a string q. A sequence of k strings s1, s2, ..., sk is called beautiful, if the concat ...

  4. mongodb系列~关于双活状态的mongodb集群

    一简介:说说我们异地双活的集群 二 背景:需要建立异地双活的架构 三 构建 1 需要保证第二机房至少两个副本集DB,这样在第一机房挂掉后才能保证第二机房的可用性 2 集群状态下第二机房启用config ...

  5. JQuery中的$.getScript()、$.getJson()和$.ajax()方法

    $.getScript() 有时候,在页面初次加载时就取得所需的全部JavaScript文件是完全没有必要的.虽然可以在需要哪个JavaScript文件时,动态地创建<script>标签, ...

  6. SpringBoot启动方式讲解和部署war项目到tomcat9

    1.SpringBoot启动方式讲解和部署war项目到tomcat9简介:SpringBoot常见启动方式讲解和部署war项目Tomcat 1.ide启动 2.jar包方式启动 maven插件: &l ...

  7. Jetson tx1 安装ROS

    注意,是 Jetson TX1 系统版本: R24.2 参考链接: https://www.youtube.com/watch?v=-So2P0kRYsk

  8. ubuntu14.04 + cuda8.0 + cudnnv5 + caffe + py-faster-rcnn配置

    经过几天的奋战终于配置好了如题所述的配置,现在把配置大体过程写下来供大家配置时参考(由于电脑硬件和系统的千差万别,实在不适合写详细的) (一切不声明配置环境的配置教程都是耍流氓) 环境: Inter集 ...

  9. zabbix3.0监控centos当主机cpu使用率超过90%的时候报警

    在windows系统中监控cpu利用率非常容易,自带模板就有这样的功能,但是在linux里面没有默认的模板 只有cpu的负载,默认当cpu的负载在一定时间内5以上报警 cpu utilization中 ...

  10. Python-JS基础(基础结构~函数)

    程序本质上分为三大结构: 顺序结构.分支结构.循环结构JavaScript中的程序结构也是这样,下面我们来分别介绍JS中的三种基本程序结构:我们上篇博客中介绍到的使用逻辑运算符&&实现 ...