Mysql面试常见知识点总结(一)

一、Mysql事务相关
事务特点,包括原子性、一致性、隔离性、持久性。一句话表达就是逻辑上的一组操作,要么执行,要不不执行。
事务的隔离性包括读取未提交、读取已提交、可重复读、串行化。这四种事务隔离性是按照从低到高的隔离级别。默认级别是可重复读。
1、读取未提交是指一个事务内可以读取另一个事务内已修改但没有commit提交的数据。
2、读取已提交是指一个事务内可以读取另一个事务内已提交的数据。可避免脏读。
3、可重复读是指一个事务内可以反复读取另一个事务内某个字段的值,而不会有差异性。即对同一个字段进行多次读操作,得到的结果是相同的。可避免脏读、不可重复读。
4、串行化就是多个事务之间完全独立,按照顺序执行。可避免事务并行带来的不利影响。可避免脏读、不可重复读、幻读。
并发事务可能造成一些错误数据,包括脏读、不可重复读、以及幻读。可以提高事务的隔离性,来避免并发事务带来的影响。
1、脏读就是指一个事务内读取另一个事务内已修改但未提交的数据,从而产生错误。
2、不可重复读,一个事务内读取到另一个事务内对某一个字段的修改值。
3、幻读,就是一个事务内读取某些记录,但是另一个事务内有新增或删除了某些记录,这个时候第一个事务再进行查询操作,会增加或者减少了部分记录。

二、Mysql引擎特点
mysql5.6版本后采用InnoDb引擎,支持表级锁和行级锁。并且支持事务。

三、Mysql设计表
1、采用合适的数据类型。比如Int、smallInt等占用不同的字节数,根据实际使用场景采用合适的数据类型。
若不涉及到符号,则采用无符合数据类型。
日期数据不要采用字符类型,采用Date、DateTime、Time、TimeStamp等。DateTime占八个字节,时间范围大。TimeStamp时间范围从1980-2040,带有时区信息。
Ip设计成Int类型,而不采用字符类型
尽量不要有null、建立好主键。
2、建立合适的索引
建议在where、OrderBy、GroupBy等字段上选择列作为索引。索引一般不超过五个,索引不是越多越好,过多的索引的情况下。若数据的变更使得索引维护的开销增加,当然Mysql选择索引的时间也会增加。
索引列的顺序尽量选取区分度高的列,再就是列长度较短的放在前面。
区分度高的字段做索引,容易命中记录。列长度较小的字段,容易减小IO开销。

四、Sql查询慢
1、检查Sql是否规范,是否没有建立索引或者说有索引但是由于Sql语句不规范而没有走索引。
常见的不走索引而去全表查找的问题如使用Like “%%”、!=或者<>、或者对列采用函数转换或者左侧运算、或者在Where条件中使用Is null、Is not null或者使用In子查询,将会放弃索引,而走整表查询,从而降低效率。
2、大Sql的话,建议拆分成多个小Sql。一个Sql语句是单线程执行。
3、若是数据量太大,则考虑读写分离、或者分区(垂直分区、水平分区)、分库等。
读写分离是比较经典的做法,主数据库做写操作,多个从数据库负责读操作。
垂直分区就是把多个列拆开,可以按照操作频繁的列作为一张表。
水平分区就是将一张表上的记录分到多张表上去。
分库则是物理上的分隔,分布式部署。

五、慢查询排查
1、开启慢查询日志,分析查询Sql耗时
2、采用Explain分析Sql执行情况,是否命中索引等

感谢歪哥总结,参考博文地址:http://blog.waizaowang.com/java/19.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值