常问的MySQL面试题整理
- char、varchar 的区别是什么?
- varchar是变长而char的长度是固定的。如果创建的列是固定大小的,你会得到更好的性能
- truncate 和 delete 的区别是什么?
- delete 命令从一个表中删除某一行,或多行,可以使用用where,truncate 命令清空表里的所有数据,再插入数据时自增 id 从 1 开始
- 什么是触发器,MySQL 中都有哪些触发器?
- 触发器是指一段代码,当触发某个事件,自动执行这些代码(维护数据库的一致性的完整性)。MySQL中的触发器有如下六种:
- Before Insert
- After Insert
- Before Update
- After Update
- Before Delete
- After Delete
- float 和 double 的区别是什么?
- float 类型数据可以存储之多8位十进制数,并在内存中占4字节
- double类型数据可以存储至多18位十进制数,并在内存中占8字节
- 如何在 MySQL 中获取当前日期?
- select curdate();
- select current_date();
- select date_format(now(), '%y%m%d');
- 如何查询第 n 高的工资?
- select distinct(salary) from employee order by salary desc limit n-1, 1;
- 请写出下面 MySQL 数据类型表达的意义(int(0), char(16), varchar(16), datetime, text)
数据类型考点:
- 1、整数类型:包括 tinyint、smallint、mediumint、int、bigint、分别表示1字节、2字节、3字节、4字节、8字节整数。任何整数类型都可以加上unsigned,表示数据是无符号的,即非负整数。
- 长度:整数类型可以被指定长度,例如:int(11)表示长度为11的int类型。长度在大多数场景是没有意义的,它不会限制值的合法范围,指挥影响显示字符的个数,而且需要和unsigned和zerofill属性配合使用才有意义。
- 例子:假设数据类型为int(5),属性为unsigned zerofill,如果用户插入的数据为12的话,那么数据库实际存储数据为00012.
- 2、实数类型:包括float、double、decimal。
- decimal可以用于存储比bigint还大的整数,能存储精确的小数。
- 而float和double是由取值范围的,并支持使用标准的浮点进行近似计算。
- 计算时float和double相比decimal效率更高一些,decimal可以理解为用字符串进行处理(保证数据不会失真)
- 3、字符串类型:包括varchar、char、text、blob
- varchar 用于存储可变长字符串,比定长类型更节省空间
- varchar 使用额外1个或2个字节存储字符串长度。列长度小于255字节时,使用1字节表示,负责小于2字节表示
- varchar 存储的内容超出设置的长度时,内容会被截断
- char 是定长的,根据定义的字符串长度分配足够的空间
- char 会根据需要使用空格进行填充方便比较
- char 适合存储很短的字符串,或者所有值都接近同一个长度
- char 存储的内容超出设置的长度时,内容同样会被截断
- 字符串使用策略:
- 对于经常变更的数据来说,char比varchar更好,因为char不容易产生碎片
- 对于非常短的列,char比varchar在存储空间上更有效率
- 使用时要注意只分配需要的空间,更长的列排序时会消耗更多内存
- 尽量避免使用text/blob类型,查询时会使用临时表,导致严重的性能开销
- 4、枚举类型(ENUM):把不重复的数据存储为一个预定义的集合
- 有时可以使用enum代替常用的字符串类型
- enum存储非常紧凑,会把列表值压缩到一个或两个字节
- enum在内部存储时,其实存的是整数
- 尽量避免使用数字作为enum枚举的常量,因为容易混乱
- 排序是按照内部存储的数据
- 5、日期和时间类型:尽量使用timestamp,空间效率高于datetime,但是如果表中有timestamp类的列,每次更新时timestamp列都会自动更新为当前时间戳
- 1、整数类型:包括 tinyint、smallint、mediumint、int、bigint、分别表示1字节、2字节、3字节、4字节、8字节整数。任何整数类型都可以加上unsigned,表示数据是无符号的,即非负整数。
MySQL基础操作
MySQL的连接和关闭:mysql -u -p -h -P
-u:指定用户名
-p:指定密码
-h:主机
-P:端口
进入MySQL命令行后:G、c、q、s、h、d
G:打印结果垂直显示
c:取消当前MySQL命令
q:退出MySQL连接
s:显示服务器状态
h:帮助信息
d:改变执行符
MySQL存储引擎:
1、InnoDB存储引擎
- 默认事物型引擎,最重要最广泛的存储引擎,性能非常优秀。
- 数据存储在共享表空间,可以通过配置分开。也就是多个表和索引都存储在一个表空间中,可以通过配置文件改变此配置
- 对主键查询的性能高于其他类型的存储引擎
- 内部做了很多优化,从磁盘读取数据时会自动构建hash索引,插入数据时自动构建插入缓冲区
- 通过一些机制和工具支持真正的热备份
- 支持崩溃后的安全回复
- 支持行级锁
- 支持外键
2、MyISAM存储引擎
- 拥有全文索引、压缩、空间函数
- 不支持事物和行级锁、不支持崩溃后的安全恢复
- 表存储在两个文件,MYD(MY date)和MYI(MY index)
- 设计简单,某些场景下性能很好,例如获取整个表有多少条数据,性能很高。
- 全部索引不是很常用,不如使用外部的ElasticSearch
3、其他引擎
Archive、Blackhole、CSV、Memory
使用策略:在大多数场景下建议使用InnoDB存储引擎
MySQL锁机制
表锁是日常开发中的常见问题,因此也是面试中最常见的考察点,当多个查询同一时刻进行数据修改时,就会产生并发控制的问题。共享锁和排它锁,就是读锁和写锁
- 共享锁:不堵塞,多个用户可以同时读同一个资源,互不干扰
- 排他锁:一个写锁会堵塞其他的读锁和写锁,这样可以只允许一个用户进行写入,防止其他用户读取正在写入的资源
锁的粒度 - 表锁:系统开销最小,会锁定整张表,MyISAM使用表锁
- 行锁:最大程度的支持并发处理,但是也带来了最大的锁开销,InnoDB使用行锁
MySQL事物处理
- MySQL提供事物处理的表引擎,InnoDB
- 服务器层不管理事物,由下层的引擎实现,所以同一个事物中,使用多种引擎是不靠谱的
- 需要注意,在非事物表上执行事物操作,MySQL不会发出提醒,也不会报错
存储过程
- 为以后的使用保存的一条或多条MySQL语句的集合,因此也可以在存储过程中加入业务逻辑和流程
- 可以在存储过程中创建表,更新数据,删除数据等等
使用策略
- 可以通过把SQL语句封装在容易使用的单元中,简化复杂的操作
- 可以保证数据的一致性
- 可以简化对变动的管理
常问的MySQL面试题整理的更多相关文章
- 常问的MySQL面试题集合
关注「开源Linux」,选择"设为星标" 回复「学习」,有我为您特别筛选的学习资料~ 除了基础题部分,本文还收集整理的MySQL面试题还包括如下知识点或题型: MySQL高性能索引 ...
- 企业面试题|最常问的MySQL面试题集合(二)
MySQL的关联查询语句 六种关联查询 交叉连接(CROSS JOIN) 内连接(INNER JOIN) 外连接(LEFT JOIN/RIGHT JOIN) 联合查询(UNION与UNION ALL) ...
- 企业面试题|最常问的MySQL面试题集合(一)
问题1:char.varchar的区别是什么?varchar是变长而char的长度是固定的.如果你的内容是固定大小的,你会得到更好的性能. 问题2: TRUNCATE和DELETE的区别是什么?DEL ...
- 企业面试题|最常问的MySQL面试题集合(三)
分区表的原理 分库分表的原理 延伸: MySQL的复制原理及负载均衡 分区表的工作原理 对用户而言,分区表是一个独立的逻辑表,但是底层MySQL将其分成了多个物理子表,这对用户来说是透明的,每一个分区 ...
- 金九银十跳槽高峰,面试必备之 Redis + MongoDB 常问80道面试题
前言 有着“金九银十”之称的招聘旺季已经开启,跳槽高峰期也如约而至. 本文为主要是 Redis + MongoDB 知识点的攻略,希望能帮助到大家. 内容较多,大家准备好耐心和瓜子矿泉水. Redis ...
- Java集合必会14问(精选面试题整理)
前言:把这段时间复习的关于集合类的东西整理出来,特别是HashMap相关的一些东西,之前都没有很注意1.7 ->> 1.8的变化问题,但后来发现这其实变化挺大的,而且很多整理的面试资料都没 ...
- mysql面试题整理
1 myisam 和 innodb 引擎的区别 innodb 支持事务,外键,myisam 不支持 innodb 支持 mvcc ,myisam 不支持 innodb 支持表锁.行锁,myisam 仅 ...
- android-------Java 常问的基础面试题
1."=="和equals方法究竟有什么区别? ==操作符专门用来比较两个变量的值是否相等,也就是用于比较变量所对应的内存中所存储的数值是否相同,要比较两个基本类型的数据或两个 ...
- MySql面试题、知识汇总、牛客网SQL专题练习
点击名字直接跳转到链接: Linux运维必会的100道MySql面试题之(一) Linux运维必会的100道MySql面试题之(二) Linux运维必会的100道MySql面试题之(三) Linux运 ...
随机推荐
- stm32CubeMx+TrueSTUDIO+uc/os-III移植开发(一)
自从接触到stm32cubemx后,发现使用起来很方便,用来做项目开发的话,由于是图形化操作界面,工作效率比较快.如果要学习操作系统,以前的IDE如keil,IAR等IDE对操作系统的代码调试起来不够 ...
- 一个完整的机器学习项目在Python中的演练(一)
大家往往会选择一本数据科学相关书籍或者完成一门在线课程来学习和掌握机器学习.但是,实际情况往往是,学完之后反而并不清楚这些技术怎样才能被用在实际的项目流程中.就像你的脑海中已经有了一块块"拼 ...
- Activiti7流程定义
一.什么是流程定义 流程定义是线下bpmn2.0标椎去描述业务流程,通常使用activiti-explorer(web控制台)或 activiti-eclipse-designer 插件对业务流程进行 ...
- windows10远程桌面,出现“出现身份验证错误 要求的函数不受支持...”等错误解决方法
windows家庭普通版,更新补丁后无法远程连接windows server2012,出现以下报错: 解决方法: 1.win + R打开运行,输入 regedit,回车进入注册表 2.找到以下路径 \ ...
- Java方法调用数组,是否改变原数组元素的总结
Java方法调用数组,是否改变原数组元素的总结 //个人理解, 欢迎吐槽 注意String是引用型变量, 我的理解也就是指向型, 指向一个数据或变量, 画图理解最容易, string 指向的 数据的值 ...
- JavaScipt创建函数的方法
JavaScipt的函数的定义有三种方式: 一.命名函数定义 1.JavaScript 函数通过 function 关键词进行定义,其后是函数名和括号 (). 2.函数名可包含字母.数字.下划线和美 ...
- 面试刷题31:分布式ID设计方案
面试中关于分布式的问题很多.(分布式事务,基本理论CAP,BASE,分布式锁)先来一个简单的. 简单说一下分布式ID的设计方案? 首先要明确在分布式环境下,分布式id的基本要求. 1, 全局唯一,在分 ...
- Scala环境及IDEA配置
Scala环境及IDEA配置 1 语言介绍 他已经出生15年了,就像明星一样,谁都不可能一开始就人气爆棚粉丝无数,得慢慢混. 成功原因:完全兼容java代码. 身世介绍 Scala在2004年正式问世 ...
- 2019NYIST计科第七次周赛总结
2019NYIST计科第七次周赛总结 文章目录 2019NYIST计科第七次周赛总结 [秤取物体重量( 二进制枚举法)](https://blog.csdn.net/qq_34261446/artic ...
- Java 为 Excel 中的行设置交替背景色
在制作Excel表格时,通过将数据表中上下相邻的两行用不同的背景色填充,可以使各行的数据看起来更清楚,避免看错行,同时也能增加Excel表格的美观度.本文将介绍如何在Java程序中为 Excel 奇数 ...