MySQL QA
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的更多相关文章
- 怎样知道linux是否安装了mysql
1. 使用 [root@localhost Desktop]# rpm -qa |grep mysql (-qa查询已经安装的软件) mysql-libs-5.1.71-1.el6.x86_64 结果 ...
- spring整合atomikos实现分布式事务
前言 Atomikos 是一个为Java平台提供增值服务的并且开源类事务管理器,主要用于处理跨数据库事务,比如某个指令在A库和B库都有写操作,业务上要求A库和B库的写操作要具有原子性,这时候就可以用到 ...
- Linux安装MySql5.7及配置(yum安装)
Linux安装MySql5.7及配置(yum安装) [root@xld ~]# rpm -q centos-release centos-release-7-7.1908.0.el7.centos.x ...
- linux安装好的mysql rpm -qa |grep mysql不见
输入: rpm -qa|grep -i mysql
- QA:无法为具有固定名称“MySql.Data.MySqlClient”...
Question: 无法为具有固定名称“MySql.Data.MySqlClient”的 ADO.NET 提供程序加载在应用程序配置文件中注册的实体框架提供程序类型“MySql.Data.MySqlC ...
- MySQL高级知识- MySQL的架构介绍
[TOC] 1.MySQL 简介 概述 MySQL是一个关系型数据库管理系统,由瑞典MySQL AB公司开发,目前属于Oracle公司. MySQL是一种关联数据库管理系统,将数据保存在不同的表中,而 ...
- Centos6.5下编译安装mysql 5.6
一:卸载旧版本 使用下面的命令检查是否安装有MySQL Server rpm -qa | grep mysql 有的话通过下面的命令来卸载掉 rpm -e mysql //普通删除模式 rpm -e ...
- centos下彻底删除 和重装MYSQL
1 删除Mysql yum remove mysql mysql-server mysql-libs mysql-server; find / -name mysql 将找到的 ...
- Linux1 在Linux(CentOS)上安装MySql详细记录
前记: 毕业两年了,前两天换了份工作,由以前的传统行业跳到了互联网行业.之前的公司一直在用WinServer2003+Tomcat+SqlServer/Oracle这套部署环境.对于Linux+To ...
随机推荐
- SVG2PNG(前台和后台将SVG转换为PNG)--amcharts导出png
在项目中用到了amcharts,amcharts图标统计插件是利用SVG实现的,其自带下载png功能,但是不支持IE以下浏览器.因此研究了SVG转换为png,最终实现的效果是将amcharts生成一张 ...
- 推荐系统之协同过滤的原理及C++实现
1.引言 假如你经营着一家网店,里面卖各种商品(Items),有很多用户在你的店里面买过东西,并对买过的Items进行了评分,我们称之为历史信息,现在为了提高销售量,必须主动向用户推销产品,所以关键是 ...
- JS判断页面是否出现滚动条
今天无聊,帮一个网友解决一个很无聊的问题,用JS判断页面是否出现滚动条,在网上看了一些代码,经过验证并不起作用,下面是在网上搜索到的代码: 当可视区域小于页面的实际高度时,判定为出现滚动条,即: if ...
- 【转】OpenCV对图片中的RotatedRect进行填充
函数名:full_rotated_rect 函数参数: image输入图像,rect希望在图像中填充的RotatedRect,color填充的颜色 主要的思路是:先找到RotatedRect的四个顶点 ...
- client模式下对应接口加入桥接出错
client模式下,响应的接口wlan0 加入桥接时出现如下错误: root@root:~# brctl addif br-lan wlan0brctl: bridge br-lan: Operati ...
- 转载:2.2.4 配置项的单位《深入理解Nginx》(陶辉)
原文:https://book.2cto.com/201304/19629.html 大部分模块遵循一些通用的规定,如指定空间大小时不用每次都定义到字节.指定时间时不用精确到毫秒. 当指定空间大小时, ...
- GitHub上优秀的Go开源项目
近一年来,学习和研究Go语言,断断续续的收集了一些比较优秀的开源项目,这些项目都非常不错,可以供我们学习和研究Go用,从中可以学到很多关于Go的使用.技巧以及相关工具和方法.我把他们整理发出来,大家有 ...
- Node.js ECONNREFUSED错误
1 现象 node服务器 遇见此错误,如下:events.js:71throw arguments[1]; // Unhandled 'error' event^Error: connect ECON ...
- [学习笔记]JS计数器,闭包和localStorage
1.前言 Javascript也算用了挺久了,为了得到一个变量,类似Java的静态变量的功能,我想到了很早以前学习JS的闭包,还有做俄罗斯方块的排行榜用到LocalStorage技术,所以想总结一下, ...
- 常见的js算法
参考地址:链接