首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

MySQL索引SQL语句优化

在字段上计算不能命中索引, 10、强制类型转换会全表扫描,   如果phone字段是varcher类型,则下面的SQL不能命中索引。...13、建立索引的列不能为null,使用not null约束及默认值 14、利用延迟关联或者子查询优化超多分页场景, MySQL并不是跳过offset行,而是取offset+N行,然后放弃前offset...行,返回N行,那当offset特别大的时候,效率非常低下,要么控制返回的总数,要么对超过特定阈值的页进行SQL改写。...select id,name from product limit 866613, 20 使用上述SQL语句做分页的时候,可能有人会发现,随着表数据量的增加,直接使用limit分页查询会越来越慢。...SQL可以采用如下的写法:select id,name from product where id> 866612 limit 20。

1.6K10
您找到你想要的搜索结果了吗?
是的
没有找到

MySQL SQL优化之覆盖索引

内容概要 利用主索引提升SQL的查询效率是我们经常使用的一个技巧,但是有些时候MySQL给出的执行计划却完全出乎我们的意料,我们预想MySQL会通过索引扫描完成查询,但是MySQL给出的执行计划却是通过全表扫描完成查询的...前些天,有个同事跟我说:“我写了个SQLSQL很简单,但是查询速度很慢,并且针对查询条件创建了索引,然而索引却不起作用,你帮我看看有没有办法优化?”。...那为什么MySQL没有利用索引(uni_order_code)扫描完成查询呢?因为MySQL认为这个场景利用索引扫描并非最优的结果。我们先来看下执行时间,然后再来分析为什么没有利用索引扫描。...执行计划显示查询会利用覆盖索引,并且只扫描了1000行数据,查询的性能应该是非常好的。 执行时间:13ms ? 从执行时间来看,SQL的执行时间提升到原来的1/20,已经达到我们的预期。...要写出性能很好的SQL不仅需要学习SQL,还要能看懂数据库执行计划,了解数据库执行过程、索引的数据结构等。

1.7K60

MySQLMySQLSQL语句的索引分析

MySQLSQL语句的索引分析 了解过 索引 的概念以及 B+树 的概念之后,我们就来看看怎么分析一条查询语句的索引使用情况。...相信不少同学应该都使用过 EXPLAIN 来分析 SQL 语句,但是具体到 EXPLAIN 中每个字段的作用,可能有不少同学还是会有点晕的。...const 根据主键或唯一索引进行等值查询时,MySQL 发现能对查询条件优化成常数时,访问方法就是 const 。常数级别也就是速度非常非常快,常见于主键等值查询。...不过某些情况下,MySQL 的优化器在计算到走索引还不如走全表时,也会直接使用全表扫描,以后我们踫到这种问题了再单独拿出来说吧。...参考文档: 《MySQL是怎样运行的》

10110

MySQL SQL索引优化总结

专栏持续更新中:MySQL详解 首先我们需要知道MySQL主要是从以下3个方面进行优化: SQL语句和索引 应用优化(引入缓存、连接池) 配置参数优化 一、SQL语句和索引的优化 当数据量比较大,若SQL...语句写的不合适,会导致SQL的执行效率低,我们需要等待很长时间才能拿到结果 针对性优化的时候,若数据量太大,可通过limit分页 explain分析的时候可能出现以下问题: 没有用索引 用多列索引没有用到第一列...,导致没用到索引 联合查询的大小表设置不合理,导致索引没用上(小表是整表查询,大表才用索引) 多表查询不用in(产生中间表),用外连接替代带in子查询的过程,合理使用索引 二、应用优化 除了优化SQL索引...MySQL查询缓存 MySQL的查询缓存是把上一次select的查询结果记录下来放在缓存当中,下一次再查询相同内容的时候,直接从缓存中取出来就可以了,不用再进行一遍真正的SQL查询(在内存中划分一块空间用做缓存的地方...SQL请求就可以了,执行完成后,不销毁线程,而是把线程再归还到线程池中,等待下一次任务的处理(线程池的线程数量随着请求越来越多,是可以动态增加的) 配置完thread_cache_size,重启MySQL

19150

SQL优化 MySQL版 – 索引分类、创建方式、删除索引、查看索引SQL性能问题

索引分类 单值索引 单的意思就是单列的值,比如说有一张数据库表,表内有三个字段,分别是 id name age,我给age这个字段加一个索引,这就是单值索引,因为只有age这一列是索引; 一个表可以有多个单值索引...,我要删除的索引名字为name_index on 它属于 tb 表 查询索引 语法:show index from tb; 解析,看一下tb这张表的索引SQL性能问题 1.分析SQSL的执行计划 通过...explain,可以模拟SQL优化器执行SQL语句,从而让开发人员知道自己编写的状况; 查询执行计划:explain+SQL语句; 举例:explain select * From bbs_detail...key_len:实际使用索引的长度; ref:表和表之间的引用关系; rows:通过索引查询到的数据量; Extra:额外的优化信息 2.MySQL查询优化器会干扰我们的优化 我在前几章说过有关为什么会干扰我们优化好的...SQL语句,因为它内置有一个优化器,它会擅自篡改我们优化好的SQL语句;

1.2K10

oracle创建索引sql语句_mysql创建组合索引

创建索引一般分为在线索引和非在线索引,在线与非在线的区别:非在线锁表,优先创建索引,此时DML都被阻塞,所以快;相反,在线锁的是行而非表,通过临时表进行索引的创建,所以不会影响DML操作,但副作用就是慢...如果在生产环境操作,不停服务的话,势必导致创建索引期间仍有DML操作进来。另外如果是大表,那么采用非在线而导致锁表所带来的影响可能会很大。一句话,生产环境不停服的脚本操作,建议使用online。...1、创建索引。...DROP INDEX 索引名; 4、查看某个表的索引,表名需大写。 SELECT * FROM ALL_INDEXES WHERE TABLE_NAME = '表名' 5、查看某个表哪些列有索引。...SELECT * FROM ALL_IND_COLUMNS WHERE TABLE_NAME = '表名' 如果在where 子句中有OR 操作符或单独引用复合索引列的后面列则将不会走索引,将会进行全表扫描

3.7K20

Mysql中哪些Sql不走索引

要尽量避免这些不走索引sql: SELECT `sname` FROM `stu` WHERE `age`+10=30;– 不会使用索引,因为所有索引列参与了计算 SELECT `sname` FROM...` LIKE’金蝶%’ — 走索引 SELECT * FROM `houdunwang` WHERE `uname` LIKE “%金蝶%” — 不走索引 — 正则表达式不使用索引,这应该很好理解,所以这就是为什么在...SQL中很难看到regexp关键字的原因 — 字符串与数字比较不使用索引; CREATE TABLE `a` (`a` char(10)); EXPLAIN SELECT * FROM `a` WHERE...`a`=”1″ — 走索引 EXPLAIN SELECT * FROM `a` WHERE `a`=1 — 不走索引,同样也是使用了函数运算 select * from dept where dname...换言之,就是要求使用的所有字段,都必须建立索引,我们建议大家尽量避免使用or 关键字 — MySQL内部优化器会对SQL语句进行优化,如果优化器估计使用全表扫描要比使用索引快,则不使用索引

1.6K20

mysql索引abc,a=1 and c=2是否可使用索引_sql联合索引

在一次查询中,MySQL只能使用一个索引。 在真实项目中,SQL语句中的WHERE子句里通常会包含多个查询条件还会有排序、分组等。...MYSQL中常用的强制性操作(例如强制索引) https://www.jb51.net/article/49807.htm SELECT * FROM TABLE1 FORCE INDEX (FIELD1...bc 的时候用不到abc和ac 索引。...使用联合索引应该注意: MySQL使用联合索引只能使用左侧的部分,例如INDEX(a,b,c),当条件为a或a,b或a,b,c时都可以使用索引,但是当条件为b,c时将不会使用索引。...离散度更高的索引应该放在联合索引的前面,因为离散度高索引的可选择性高。考虑一种极端的情况,数据表中有100条记录,若INDEX(a,b)中a只有两种情况,而b有100种情况。

1.6K10

SQL索引

一、索引概述 介绍: 索引是帮助MySQL高效获取数据的数据结构(有序)。...FROM table_name; 删除索引 DROP INDEX index_name ON table name; 五、SQL性能分析 (一)SQL执行频率 MySQL客户端连接成功后,通过show...MySQL的慢查询日志默认没有开启,需要在MySQL的配置文件(/etc/my.cnf)中配置如下信息: #开启MySQL慢日志查询开关 slow query log=1 #设置慢日志的时间为2秒,SQL...通过nave profiling参数,能够看到当前MySQL是否支持 profile操作: SELECT @@have profiling; 执行一系列的业务SQL的操作,然后通过如下指令查看指令的执行耗时...query_id的SQL语句CPU的使用情况 show profile cpu for query query_id; (四)explain执行计划 EXPLAIN或者DESC命令获取MySQL如何执行

15320

SQL笔记(2)——MySQL的表操作与索引

SQL中,修改表中某一列的数据类型是一个重要的操作,因为数据类型决定了该列可以存储的数据种类和范围。...什么是索引 MySQL索引是一种帮助MySQL快速获取数据的数据结构,就像是书的目录一样可以快速访问特定信息。...主键索引索引列中的值必须是唯一的,不允许有空值。 普通索引MySQL中基本索引类型,没有什么限制,允许在定义索引的列中插入重复值和空值。 唯一索引索引列中的值必须是唯一的,但是允许为空值。...MyISAM和InnoDB中都可以使用全文索引。 空间索引MySQL在5.7之后的版本支持了空间索引,而且支持OpenGIS几何数据模型。...MySQL在空间索引这方面遵循OpenGIS几何数据模型规则。 前缀索引:在文本类型如CHAR,VARCHAR,TEXT类列上创建索引时,可以指定索引列的长度,但是数值类型不能指定。

1.6K20

从一次sql优化谈mysql索引

使用了seller_id索引,扫描了106184行。 2:新sql改造 基于上述老的查询sql,我们做了以下改造: <!...三、扯一扯索引 1:基本概念 首先看一下sql查询的执行过程: ?...客户端先发送一条查询给服务器; 服务器先检查查询缓存,如果命中了缓存,则立刻返回给存储在缓存中的结果,否则进入下一个阶段; 服务器端进行SQL解析、预处理,再由优化器生成对应的执行计划; MySQL 根据优化器生成的执行计划...老sql执行过程 解析sql,生成执行计划,选择seller_id索引树执行查询 扫描了10684行记录找到记录 回表从主键索引树取出50条数据,选择50条返回(偏移量从0开始50条,如果偏移量从10000...sql优化 根据具体的查询场景和诉求,对sql进行改造,或者适当调整索引,从而短期提供单表高性能响应,并且此方案没有额外的机器成本,只需要对底层sql检索语句进行优化,当然这也需要更高的认知成本

1.1K62

MySQL优化方案(一)优化SQL脚本与索引

本文记录MySQL优化方案 ,梗概如下: 优化SQL 优化索引 (一)优化SQL 1、通过MySQL自有的优化语句 优化SQL语句,通过脚本命令来了解执行率较低的语句,显示一下状态等。...SHOW命令 SHOW Status可以了解SQL的执行频率。可以显示日志,显示特定的数据库、表、索引以及进程还有权限表中的信息等等。 ?...EXPLAIN 通过EXPALIN命令可以分析低效的SQL执行计划。...MySQL会想Select * 那样进行全表扫描遍历。使用> <给定区间较好。 (二)优化索引 MySQL索引是在存储引擎层面实现的,并不是在服务器层面实现的。...所以每一种的存储引擎的索引都是不是完全相同的。 MySQL目前提供了一下4种索引(概念)。 B-Tree索引:最常见的搜索引擎。大部分的搜索搜索引擎是支持B-Tree。

2.3K70

SQL优化 MySQL版 – B树索引详讲

为什么要进行SQL优化呢?...很显然,当我们去写sql语句时: 1会发现性能低 2.执行时间太长, 3.或等待时间太长 4.sql语句欠佳,以及我们索引失效 5.服务器参数设置不合理 SQL语句执行过程分析 1.编写过程: 编写过程就是我们平常写...,查这个“王”之前先去翻看目录,发现“W”在300页,因为王首字母是“W”,我们直接去在300页中找,这样找起来就非常快; 索引在数据库中是关键字insex,用官方的定义的意思来说,索引就是帮助MySQL...其实它就是一个树,我们用的比较多的就是B树、Hash树,在MySQL里面,用的就是B树索引; B树索引 首先我画一个图,假装这个是数据表,并且给age列加一个索引: 就把这个索引当成一个目录,也就是age...IO的使用率 2.降低CPU使用率 比如说我sql里面有一个order by desc 根据年龄降序或升序,如果没有索引,你需要把age全部拿出来全部排个序,但是如果有了索引,你就不需要排序了,B树本身就是一个排好序的结构

32010

MySQLSQL 语句为什么不走索引

发表于2019-08-212020-03-03 作者 Ryan 首先, 明确一下在MySQL 中,执行 SQL 语句流程如下(图来自网络): image.png 一条 SQL...SQL 命令解析器;2. 代价分析器;代价分析器没有在这个图中展示出来;这也是 SQL 未命中索引的关键所在。...下面来讲一下,如何定位 SQL 未走索引的原因 我们大部分情况下,使用的是 Explain 来分析 SQL 语句是否走索引,即便语法分析的时候是走了索引的,执行的时候,还是有可能没有走索引...如果你详细看过 MySQL 官方网站的说明文档,会看到这一章节内容:Chapter 8 Tracing the Optimizer (https://dev.mysql.com/doc/internals...在执行 SQL 的的时候,对 SQL 的执行代价会有个判断,如果走索引的代价,超过不走索引,那它就放弃使用索引,也就是我们执行 SQL 时,所遇到的 explain 分析走索引,真正线上执行没有走索引的原因

1.3K10

SQL学习笔记之MySQL索引知识点

0x00 概述 之前写过一篇Mysql B+树学习,简单的介绍了B+数以及MySql使用B+树的原因, 有了这些基础知识点,对MySql索引的类型以及索引使用的一些技巧,就比较容易理解了。...select a from table xxx where b = 2 像上面这个语句,如果只是为列b建立索引,那么执行这个SQL是可以用到索引的,但是由于a列的数据并没有在这个b索引中,索引需要再次访问聚集索引文件...这里再举一个例子,分页查询 select id,code from xxxx order by age limit 50000,10; 如果只是在age列建立索引的话,这个SQL查询的效率不高,但是建立...0x04索引列不要参与计算 B+数存的是key和数据,如要查询的时候,需要对树中的数据先计算后再比较,代价太大了,也极其的慢,因此索引列使用了函数,压根就无法用到索引,MySql也不支持这样做。...因为像b=11或者b in (11,22)这种查询, MySql是会优化的,可以用到索引的,可以放心使用。 参考 参考2

34010

mysql 前缀索引_MySQL前缀索引

有时候需要索引很长的字符字段列,这会增加索引的存储空间以及降低索引的查询效率,一种策略是可以使用哈希索引,还有一种就是使用前缀索引。...前缀索引是选择字符列的前n个字符作为索引,这样可以大大节约索引空间,从而提高索引效率。...前缀索引的选择性 使用前缀索引,在一些场景下可能使得重复的索引值变多,索引的选择性变低,查找时需要过滤更多的行,因此建立前缀索引也要考虑前缀的索引选择性不能太低。...MySQL 无法使用前缀索引做 ORDER BY 和 GROUP BY , 也无法使用前缀索引做覆盖扫描。...后缀索引 MySQL 没有提供后缀索引,事实上,一些业务场景对后缀匹配选择性更高,比如我曾经参与过的项目,手机的入网标示imei号,前缀都是86等固定的国家编号开头,这个时候可以将字符反转后存储,就可以建立选择性较高的前缀索引

4.8K30

扫码

添加站长 进交流群

领取专属 10元无门槛券

手把手带您无忧上云

扫码加入开发者社群

相关资讯

热门标签

活动推荐

    运营活动

    活动名称
    广告关闭
    领券