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

Mysql查询语句优化

前言 上一篇文章 《MySQL索引原理机器优化》讲了索引的一些原理以及优化方案,这一次学习对查询的优化,毕竟快速的查找到数据才是我们的最终目的....分析查询 想要对一条查询语句进行优化,首先要对其进行分析,MySQL提供了这个机制, 可以通过explain sql 或者desc sql的语法去获取MySQL对某一条语句的执行计划(MySQL优化之后的...查询优化 对一条sql的优化可以分为两部分,第一部分是对语句优化,比如将子查询改写为join等,第二部分是与索引相关的优化,在这一阶段可能会修改语句以让查询尽可能的命中索引,甚至会通过修改索引来达到这个目的...查询语句优化 检查语句 查询语句优化的第一步,首先从大的层面上分析一下语句,得到以下问题的答案: 是否请求了不需要的数据?...STRAIGHT_JOIN 该hint告诉MySQL按照语句中的顺序进行多个表的关联操作,不要进行”优化”.select STRAIGHT_JOIN * from table1 join table2.

5.1K20

MySQL 语句优化 ICP

ICP介绍 Index Condition Pushdown(ICP)是MySQL 5.6中的的新特性,是一种在存储引擎层使用索引过滤数据的一种优化方式。...ICP可以减少存储引擎访问基表的次数以及MySQL服务器访问存储引擎的次数。 当MySQL使用索引从表中检索行时,索引条件下推(ICP)是一种优化。...AND name LIKE '%639@qq.com'; 指标观察: Handler_read_first:此选项表明SQL是在做一个全索引扫描,注意是全部,而不是部分,所以说如果存在WHERE语句...table_condition_attached: 在attaching_conditions_to_tables阶段添加了附加条件的条件语句。 access_type:优化后的索引访问类型。...擅长MySQL、Redis、MongoDB数据库高可用设计和运维故障处理、备份恢复、升级迁移、性能优化。自学通过了MySQL OCP 5.6和MySQL OCP 5.7认证。

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

MySQL——优化ORDER BY语句

MySQL——优化ORDER BY语句 本篇文章我们将了解ORDER BY语句优化,在此之前,你需要对索引有基本的了解,不了解的老少爷们可以先看一下我之前写过的索引相关文章。现在让我们开始吧。...ORDER BY优化的核心原则 尽量减少额外的排序,通过索引直接返回有序数据。...ORDER BY优化实战 用于实验的customer表的索引情况: 首先要注意: MySQL一次查询只能使用一个索引,如果要对多个字段使用索引,建立复合索引。...根据两种排序算法的特性,适当加大系统变量maxlengthforsortdata的值,能够让MySQL选择更优化的Filesort排序算法。...并且在书写SQL语句时,只使用需要的字段,而不是SELECT * 所有的字段,这样可以减少排序区的使用,提高SQL性能。

1.1K21

Mysql Join语句优化

尽可能减少Join语句中Nested Loop的循环总次数 最有效的办法是让驱动表的结果集尽可能地小,这也正是在本章第二节中所提到的优化基本原则之一——“永远用小结果集驱动大结果集” 比如,当两个表(表...优先优化Nested Loop的内层循环 不仅在数据库的Join中应该这样做,实际上在优化程序语言时也有类似的优化原则。...保证Join语句中被驱动表的Join条件字段已经被索引 其目的正是基于上面两点的考虑,只有让被驱动表的Join条件字段被索引了,才能保证循环中每次查询都能够消耗较少的资源,这也正是内层循环的实际优化方法...在这种情况下,Join Buffer的大小将对整个Join语句的消耗起到非常关键的作用

1.9K60

Mysql性能优化一:SQL语句性能优化

这里总结了52条对sql的查询优化,下面详细来看看,希望能帮助到你 1, 对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引。...存储过程是编译好、优化过、并且被组织到一个执行规划里、且存储在数据库中的SQL语句,是控制流语言的集合,速度当然快。反复执行的动态SQL,可以使用临时存储过程,该过程(临时表)被放在Tempdb中。...40,mysql查询优化总结:使用慢查询日志去发现慢查询,使用执行计划去判断查询是否正常运行,总是去测试你的查询看看是否他们运行在最佳状态下。...无需在执行存储过程和触发器的每个语句后向客户端发送 DONE_IN_PROC 消息。 46,MySQL查询可以启用高速查询缓存。这是提高数据库性能的有效Mysql优化方法之一。...47,EXPLAIN SELECT 查询用来跟踪查看效果  使用 EXPLAIN 关键字可以让你知道MySQL是如何处理你的SQL语句的。这可以帮你分析你的查询语句或是表结构的性能瓶颈。

1.9K20

借助profile优化MySQL查询语句

问题 上周客户反馈有个功能比较卡,经同事排查是因为一个SQL语句查询比较慢导致的: SELECT am.article_id, am.simhash FROM...都改成char(24),发现没什么效果,看来MySQL也不会那么傻。...这个语句命中的记录行数确实是比较多的(3.6万多),但是返回的两个字段都是业务需要的。一时没了主意,想了一些准备绕过这个问题的解决方案。...后来想起phpmyadmin是可以分析sql语句的性能(MySQL profile),分析结果如下: 显然,绝大部分时间都花在了sending data上,眼前一亮,肯定是返回的数据太多或者中间过程的数据量太多...优化MySQL查询语句,单靠explain是不够的,profile往往是更加有效的方法。

1.4K20

MySQL索引与SQL语句优化

1、前导模糊查询不能使用索引,   如name like ‘%静’ 2、Union、in、or可以命中索引,建议使用in 3、负条件查询不能使用索引,可以优化为in查询,   其中负条件有!...13、建立索引的列不能为null,使用not null约束及默认值 14、利用延迟关联或者子查询优化超多分页场景, MySQL并不是跳过offset行,而是取offset+N行,然后放弃前offset...18、Select语句务必指明字段名称 19、如果排序字段没有用到索引,就尽量少排序 20、尽量用union all 代替 union。   ...select id,name from product limit 866613, 20 使用上述SQL语句做分页的时候,可能有人会发现,随着表数据量的增加,直接使用limit分页查询会越来越慢。...优化的方法如下: 可以取前一页的最大行数的id,然后根据这个最大的id来限制下一页的起点。 比如此列中,上一页最大的id是866612。

1.5K10

MySQL中SQL语句优化路径

碰巧看到杨老师的这篇文章《第45期:一条 SQL 语句优化的基本思路》,为我们优化一些MySQL数据库的SQL语句提供了可借鉴的路径,值得参考和应用。 SQL语句优化是一个既熟悉又陌生的话题。...以MySQL为例,一条SQL语句从客户端发出到数据库端返回结果一般会经历几个阶段:词法解析、语法解析、语义解析、逻辑优化、物理优化、最终执行并返回结果。...InnoDB引擎(MySQL 5.7以及以前一些老旧版本可能会有非InnoDB引擎表),如果不是,转换表引擎为InnoDB。...因为MySQL从5.5版本开始,所有针对存储层的优化都是针对InnoDB 引擎的。 极个别表为临时表。查看临时表相关参数是否设置合理;或者说能否把临时表替换为磁盘表。...经过以上几个步骤,一般的语句基本上都能达到比较优化的结果。 虽然上面说的是MySQL数据库,但是一些理论上,其他的关系型数据库都是可以借鉴的。

2K10

mysql优化sql语句的方法

1、为什么要进行mysql优化?...优化 2、数据库优化的目标?...通过各种对数据库的优化方法,获取最高的查询和加载性能,达到查询性能的提高和加载性能的提高。 3、掌握优化的方式和途径 建表、索引、配置、SQL语句都需要优化 4、掌握建表和分表优化?...原本存储于一个表的数据分块存储到多个表上 5、掌握数据库的查询优化 ①关键字一般放在SELECT查询语句的前面,用于描述MySQL如何执行查询操作、以及MySQL成功返回结果集需要执行的行数。...5、掌握MySQL数据库的索引优化 6、掌握数据库的配置优化 7、掌握数据库的查询优化 一般来说,要保证数据库的效率,要做好以下四个方面的工作:数据库设计、sql语句优化、数据库参数配置、恰当的硬件资源和操作系统

1.2K20

mysql的sql语句优化5种方式_MySQL数据库优化

2、添加索引 3、更改索引顺序 4、去掉in 5、小结 四、双表sql优化 1、建表语句 2、左连接查询 3、小结 五、避免索引失效的一些原则 六、一些其他的优化方法 1、exist和in 2、order...知识体系总结系列的第二篇,该篇的主要内容是通过explain逐步分析sql,并通过修改sql语句与建立索引的方式对sql语句进行调优,也可以通过查看日志的方式,了解sql的执行情况,还介绍了MySQL数据库的行锁和表锁...5、小结 保持索引的定义和使用顺序一致性; 索引需要逐步优化,不要总想着一口吃成胖子; 将含in的范围查询,放到where条件的最后,防止索引失效; 四、双表sql优化 1、建表语句 CREATE TABLE...底层觉得sql写的太差了,mysql加了个缓存,进行优化了。...,用于记录MySQL响应时间超过阈值的SQL语句(long_query_time,默认10秒) ; 慢日志默认是关闭的,开发调优时打开,最终部署时关闭。

1.5K40

MySQL SQL语句优化的10条建议

另外字段尽可能用not null 3、当然无可避免某些字段会用到text,varchar等字符类型,最好将text艾段的单独出另外一个表出来(用主键关联好) 4、 字段的类型,以及长度,是一个很考究开发者优化功力的一个方面...如果表数据有一定的量了,不妨用PROCEDURE ANALYSE()命令来取得字段的优化建议!...同理,只要一行数据时尽量使用limit 1 6、绝对不要轻易用order by rand(),很可能会导致mysql的灾难 7、每个表都应该设置一个ID主键,最好的是一个INT型,并且设置上自动增加的AUTO_INCREMENT...8、拆分大的DELETE或INSERT语句,因为这两个操作是会锁表的,表一锁住了,别的操作都进不来了,就我来说有时候我宁愿用for循环来一个个执行这些操作 9、不要用永久连接mysql_pconnet(...);除非你真的非常肯定你的程序不会发生意外,不然很可能也会导致你的mysql死掉 10、永远别用复杂的mysql语句来显示你的聪明,就我来说看到一次关联了三四个表的语句,只会让人觉得很不靠谱

1.1K50

MYSQL学习笔记——sql语句优化工具

前面讲解了很多mysql的基础知识,这一章讲解mysql语句优化。...、定位慢查询                                                                                       我们要对sql语句进行优化...,在优化这些语句之前,我们应该使用explain命令查看mysql的执行计划,寻找其中的可优化点。      ...explain命令的使用十分简单,只需要"explain + sql语句"即可,如下命令就是对我们刚刚的慢查询语句使用explain之后的结果: mysql> explain select * from...----+---------------+ 16 rows in set (0.00 sec)   该profile显示了每一步操作的耗时以及cpu和Block IO的消耗,这样我们就可以更有针对性的优化查询语句

82430

MySQL Cost Cost 说人话,怎优化语句

下面我们根据上面的语句以及 OPTIMIZER_TRACE反馈的信息,来看看到底MYSQL 在prepare 阶段做了什么。...OK ,在基本上准备好要优化语句后,下面就需要优化器开始优化了,一般提到优化就有次序的问题,到底怎么优化有是怎么个次序 在本次优化语句优化的步骤有 8步 ?...优化语句,首先要明白业务逻辑(能从逻辑入手的那才是高手),然后在看语句的撰写是否是标准并符合当前数据库的优化引擎的要求,最后才是添加索引。...老鸟瞟了一眼小文,“保密” 其实SQL 语句优化,可以走这样一个步骤 1 弄清语句的业务逻辑,能在业务逻辑上修改,或者优化的就不要推到语句的层面 2 在语句的层面要理解所在数据库的优化引擎大致的工作原理...,将不符合优化器的语句,进行修改 3 根据最后定型的语句,添加适当的索引,加速语句的执行

94840

mysql学习总结10 — 优化(sql语句层)-锁与sql优化

mysql学习总结10 — 优化(sql语句层)-锁与sql优化 Write By CS逍遥剑仙 我的主页: www.csxiaoyao.com GitHub: github.com/csxiaoyaojianxian...Email: sunjianfeng@csxiaoyao.com QQ: 1724338257 sql语句层的优化主要包括锁的使用、慢查询的定位、limit分页优化 1....innodb; # begin; # 执行语句... # commit; mysql> begin; mysql> update user set name="sun" where id=1; --...(2) 查询时间 mysql> show profiles; (3) 不需要分析时关闭profile mysql> set profiling = 0; 3. limit分页优化 limit offset...预处理:(1) 设置主键索引 (2) 关闭查询缓存 分页算法: limit (page-1)*length, length; 优化方法: 业务上解决:不允许翻过100页 不用offset,用条件查询

1.3K703

MySQL里几个查询语句的性能优化论证

前几天在网上看了一个帖子,描述的现象是在MySQL中,对in,or,union all的性能的比对,看完之后,我就产生了疑问。...如果单纯说是MySQL半连接的优化器性能问题,我信,但是看了文中提供的SQL语句,我感觉至少从我使用MySQL 5.7的感觉来看,这个差别会很小,或者说没有差别。...继续运行上面的语句,性能还不错,基本都在1秒钟(当然数据是在缓存里面),三种方式的性能有差异,但是远没有稳中说得那么大了。...我们继续做一个优化改进,创建一个索引出来。数据量扩大10倍,为1000万。...alter table article add key (article_category,id); 再来看看效果发现上面的3个语句的执行效率相仿。

95460

MySql常用30种SQL查询语句优化方法

2、对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引。...因为SQL只有在运行时才会解析局部变量,但优化程序不能将访问计划的选择推迟到运行时;它必须在编译时进行选择。然 而,如果在编译时建立访问计划,变量的值还是未知的,因而无法作为索引选择的输入项。...如下面语句将进行全表扫描: select id from t where num=@num 复制代码 可以改为强制查询使用索引: select id from t with(index(索引名)) where...t(…) 复制代码 13、很多时候用 exists 代替 in 是一个好的选择: select num from a where num in(select num from b) 复制代码 用下面的语句替换...无需在执行存储过程和触发器的每个语句后向客户端发送 DONE_IN_PROC 消息。 29、尽量避免向客户端返回大数据量,若数据量过大,应该考虑相应需求是否合理。

1.4K10

MYSQL 8.0 后对语句优化与特性

MYSQL 8 以后对于一些语句的处理是进行了优化的,主要有以下几个方面 1 针对语句在 in 和 exists 子查询中使用半连接的方式进行优化 2 针对子查询的物化 3 优化了子查询在使用...EXISTS 中的一些策略 4 优化了驱动表视图以及CTE 在查询中的一些方式如使用了merge 和物化的方式 5 条件下推方式的优化 等等这几类,今天来简单的说说,他们都在那些方面对这样的数据处理方式进行了优化...1 针对语句中的 in exists any 等在使用了这些查询方式后,优化的选择倾向于 semijoin , mateialization, exists , exists strategy 等策略...需要注意的地方是如果你的语句是update 或 delete的方式进行如上的语句操作,尤其是子查询的方式,进行数据的修改,那么以上的工作将无法进行,所以对于在MYSQL 8 中的数据修改还是建议分两步走...在MYSQL 8.016 后 EXISTS 和 IN 是等价的,在优化器处理中走的一个优化的方式,在 MYSQL 8.017 后 NOT IN , NOT EXISTS 等已经走了antijoin 的方式

64550

扫码

添加站长 进交流群

领取专属 10元无门槛券

手把手带您无忧上云

扫码加入开发者社群

相关资讯

热门标签

活动推荐

    运营活动

    活动名称
    广告关闭
    领券