Mysql优化一

Mysql优化一

一、存储引擎

1.查看所有引擎

SHOW ENGINES;

2.查看默认存储引擎

show VARIABLES LIKE '%STORAGE_engine%';

3.MyISAM和InnoDB

对比项 MyISAM InnoDB
主外键 不支持 支持
事务 不支持 支持
行表锁 表锁,即使操作一条记录也会锁住整个表,不适合高并发的操作 行锁,操作时只锁某一行,不对其他行有影响,适合高并发的操作
缓存 只缓存索引,不缓存真实数据 不仅缓存索引还要缓存真实数据,对内存的要求较高,而且内存的大小对其性能有决定性的影响
表空间
关注点 性能 事务
默认安装 YES YES

二、SQL执行加载顺序

From left_tableon join_condition<join_type> join right_tablewhere where_conditiongroup by group_conditionhaving having_conditionselectdistinct select_listorder by orderBy_condtionlimit limit_num

三、索引

1.定义

索引是帮助Mysql高效获取数据的数据结构。——>本质:数据结构。

其目的在于提高查询效率,可以类比于字典,可以简单理解为排好序的快速查找数据结构

数据本身之外,数据库还维护着一个满足特定查找算法的数据结构,这些数据结构以某种方式指向数据,这样就可以在这些数据结构的基础上实现高级查找算法,这种数据结构就是索引。

通常说的索引如果没有特别指明,说的都是B树(多路搜索树,并不一定是二叉的)结构组织的索引。其中聚集索引、次要索引、覆盖索引、复合索引、前缀索引、唯一索引默认都是使用B+树索引,统称索引。当然,除了B+树这种类型的索引之外,还有哈希索引等

索引会影响到查找和排序

一般来说索引也很大,不可能全部存储在内存中,因此索引往往以索引文件的方式存储在磁盘上。

2.特点

优点:提高数据检索的效率,降低了数据库的IO成本。

​通过索引对数据进行排序,降低数据排序的成本,降低了CPU的消耗。

缺点:实际上索引也是一张表,该表保存了主键与索引字段,并指向实体表的记录,所以索引也是占用空间的。

​虽然其大大调高了查询速度,同时却会降低更新表的速度。因为更新表时不仅要保存数据,还要保存一下索引文件每次更新添加了索引列的字段,都会调整因为更新所带来的键值变化后的索引信息。

​索引只是提高效率的一个因素,如果你的数据库拥有大量的表,就需要花时间研究建立最优秀的索引,或优化查询。

3.分类

  • 单值索引

    一个索引只包含单个列,一个表可以有多个单值索引。

  • 唯一索引

    索引列的值必须唯一,但允许有空值

  • 复合索引

    一个索引包含了多个列

4.基本语法

创建:UNIQUE是唯一索引, columnname只有一个是单值索引,有多个为复合索引

CREATE [UNIQUE] INDEX indexname on tablename(columnname1, columnname2...)orALERT tablename add [UNIQUE] INDEX [indexname] on (columnname1, columnname2...)

删除:

DROP INDEX [indexname] on tablename

查看

SHOW INDEX FROM tablename

5.适合建立索引的情况

  1. 主键自动建立唯一索引
  2. 频繁作为查询条件的字段应该创建索引
  3. 查询中与其他表关联的字段,外键关系建立索引
  4. 查询中排序的字段,排序字段若通过索引去访问,将大大提高排序速度
  5. 单键/组合索引的选择问题(高并发适合创建组合索引)
  6. 查询中统计或分组的字段

6.不适合创建索引的情况

  1. 频繁更新的字段

  2. where条件里用不到的字段

  3. 表记录太少

  4. 数据重复且分布平均的表字段,因此应该只为最经常查询和最经常排序的数据建立索引

    索引的选择性=不同的数目/总数目

(0)

相关推荐

  • 性能调优-MySQL索引数据结构详解与索引优化

    本篇文章主要学习了MySQL的索引的数据结构的认识,做一个大概的了解即可. 一.索引 在关系数据库中,索引是一种单独的.物理的对数据库表中一列或多列的值进行排序的一种存储数据结构,它是某个表中一列或若 ...

  • Mysql某个表有近千万数据,CRUD比较慢,如何优化?

    我是[会点代码的大叔],每天为你分享程序员干货,关注并私信我数字"1",送你一份程序员大礼包. MySQL 数据库某张表近千万的数据,CRUD比较慢,如何优化? 说实话,这个数据量 ...

  • 什么情况?MySQL居然有中“8种”索引?

    关于MySQL索引相关的内容,一直是一个让人头疼的问题,尤其是对于初学者来说.笔者曾在很长一段时间内深陷其中,无法分清"覆盖索引,辅助索引,唯一索引,Hash索引,B-Tree索引--&qu ...

  • 项目中常用的19条mysql优化

    Java编程语言是一种简单.面向对象.分布式.解释型.健壮安全.与系统无关.可移植.高性能.多线程和动态的语言.如今Java已经广泛应用于各个领域的编程开发. 一.EXPLAIN 做MySQL优化,我 ...

  • mysql 优化面试题

    https://www.cnblogs.com/jiajialeps/p/10162767.html 第一方面:30种mysql优化sql语句查询的方法 1.对查询进行优化,应尽量避免全表扫描,首先应 ...

  • 万字总结:学习MySQL优化原理,这一篇就够了!

    说起MySQL的查询优化,相信大家收藏了一堆奇技淫巧:不能使用SELECT *.不使用NULL字段.合理创建索引.为字段选择合适的数据类型..... 你是否真的理解这些优化技巧?是否理解其背后的工作原 ...

  • 不讲“武”德,万字长文讲透MySQL优化原理!

    你知道的越多,不知道的就越多,业余的像一棵小草! 你来,我们一起精进!你不来,我和你的竞争对手一起精进! 编辑:业余草 jianshu.com/p/d7665192aaaf 推荐:https://ww ...

  • mysql优化 应付面试

    show profile 问老大:不应该问  sql语句如何优化?-->应该问  这个执行过程比较慢,这里应该如何处理?具体到某个细节点. 5的版本,show profile放心用. 但新版本, ...

  • MySQL语句性能优化之Sql错误用法

    本文主要总结了慢查询优化的过程中常用的以及不合理的操作,适合所有的运维及开发人员. 1.LIMIT 语句 分页查询是最常用的场景之一,但也通常也是最容易出问题的地方.比如对于下面简单的语句,一般 DB ...

  • MYSQL数据库服务磁盘IO高问题分析与优化

    MYSQL数据库服务磁盘IO高问题分析与优化 压力测试过程中,如果因为资源使用瓶颈等问题引发最直接性能问题是业务交易响应时间偏大,TPS逐渐降低等.而问题定位分析通常情况下,最优先排查的是监控服务器资 ...

  • MYSQL数据库服务CPU高问题分析与优化

    MySQL服务性能监控分析与优化是永恒的主题,做为性能测试人员有时也要站在DBA角度出发进行适当分析与优化,这也是性能测试人员能长期生存发展之路.而资源的使用监控分析才是性能故障分析的根本首要任务.在 ...

  • MySQL Explain详解,添加索引sql优化

    EXPLAIN语法(获取SELECT相关信息) EXPLAIN tbl_name 或: EXPLAIN [EXTENDED] SELECT select_options 当我们使用select查询时发 ...