首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    MySQL灵魂十

    9、SQL Joins、统计、 随机查询10、MySQL优化1、SQL语句执行流程MySQL大体上可分为Server层和存储引擎层两部分。...2、从节点开启一个线程(I/O Thread)把自己扮演成 mysql 的客户端,通过 mysql 协议,请求主节点的二进制日志文件中的事件 。...还可以延伸到由于主从配置不一样、主库大事务、从库压力过大、网络震荡等造成主备延迟,如何避免这个问题?主备切换的时候用可靠性优先原则还是可用性优先原则?如何判断主库Crash了?...互为主备情况下如何避免主备循环复制?被删库跑路了如何正确恢复?(⊙o⊙)… 感觉越来越扯到DBA的活儿上去了。RedoLog可以先通过下面demo理解:饭点记账可以把账单写在账本上也可以写在粉板上。...适合:1、原业务的 MySQL 的业务遇到单机容量或者性能瓶颈时,可以考虑使用 TiDB 无缝替换 MySQL。2、大数据量下,MySQL 复杂查询很慢。

    98520

    MySQL索引15问,抗住!

    金三银四很快就要来啦,准备了索引的15问,相信大家看完肯定会有帮助的。 1. 索引是什么? 索引是一种能提高数据库查询效率的数据结构。它可以比作一本字典的目录,可以帮你快速找到对应的记录。...如何减少回表? 当查询的数据在索引树中,找不到的时候,需要回到主键索引树中去获取,这个过程叫做回表。...因此,MySQL5.6版本之后,选出包含“小”字后,顺表过滤age=28 11. 大表如何添加索引 如果一张表数据量级是千万级别以上的,那么,如何给这张表添加索引?...如何知道语句是否走索引查询? explain查看SQL的执行计划,这样就知道是否命中索引了。 当explain与SQL一起使用时,MySQL将显示来自优化器的有关语句执行计划的信息。...1.2.4 extra 该字段包含有关MySQL如何解析查询的其他信息,它一般会出现这几个值: Using filesort:表示按文件排序,一般是在指定的排序和索引排序不一致的情况才会出现。

    1.5K30

    mysql索引十问| 剑指offer - mysql

    以下是结合网上及此前面试时遇到的一些关于 mysql 索引的面试题。...若对 mysql 索引不太了解可先翻阅相关文章 大白话 mysql 之深入浅出索引原理 - 上 大白话 mysql 之深入浅出索引原理 - 下 什么是索引?...innodb 使用 b + 树作为索引模型的原因 Mysql 设计的使用场景比较广泛,需要对遍历查询、单条查询、数据更新都需要较好的性能支持。B + 树的特性是只在叶子节点上存储数据。...如何删除百万级别或以上的数据? 可以考虑先删掉表的索引,等删除数据后再重建索引。...如何知道语句有没有走索引查询? 可以利用 explain 查看 sql 语句的执行计划,通过执行计划来分析索引使用情况。

    90920

    单表和表?如何选择?

    ——果戈理 今天做了个小测试啊 我自己造了一百万多条(1029708条)数据 这里测试呢我们首先是编写了一个LEFT JOIN 表SQL如下 SELECT * FROM `film`...("耗时:" + ((endTime - startTime) / (1000.0 * 1000.0)) + " ms"); 最后耗时为22289.5385 ms,大约20来秒,可以看到明显比上面的表查询要快...那么如果再一次呢,模拟两个LEFT JOIN的场景 SELECT * FROM `film` LEFT JOIN `language` ON `film`.language_id...发现仅仅多了一秒左右啊 上面的表SQL,就算在language表的language_id上加了索引,也是耗时35314.184 ms 也远远没有我们的单表快 所以结论: 同样的数据,单表多次查询在正确使用下...,比表确实快不少 但表只需要一条SQL而单表需要写一大堆代码

    86620

    【译】MySQL挑战:建立10万

    本文的目的是探索一种在一台MySQL服务器上建立10w个连接的方法。我们要建立的是可以执行查询的连接,而不是10w个空闲连接。 你可能会问,我的MySQL服务器真的需要10w连接吗?...还有一些非常糟糕的实践,使用“查询慢则重并重试”的技术。这会造成雪球效应,有可能导致在几秒内需要建立上千个连接的情况。 所以我决定设置一个“小目标”,看能否实现。...MySQL服务器使用的是Percona Server的带有线程池插件的MySQL 8.0.13-4,这个插件需要支持上千个连接。...执行命令:sysbench --test=sysbench/tests/db/select.lua --mysql-host=139.178.82.47 --mysql-user=sbtest--mysql-password...这里的关键点是,如果我们想要达到10w连接,就需要为MySQL服务器分配更多的IP地址,所以我为MySQL服务器分配了两个IP地址。

    1K30

    顺丰快递:请签收MySQL灵魂十

    查询缓存:查询后的结果存储位置,MySQL8.0版本以后已经取消,因为查询缓存失效太频繁,得不偿失。 分析器:根据语法规则,判断你输入的这个SQL语句是否满足MySQL语法。...2、从节点开启一个线程(I/O Thread)把自己扮演成 mysql 的客户端,通过 mysql 协议,请求主节点的二进制日志文件中的事件 。...还可以延伸到由于主从配置不一样、主库大事务、从库压力过大、网络震荡等造成主备延迟,如何避免这个问题?主备切换的时候用可靠性优先原则还是可用性优先原则?如何判断主库Crash了?...互为主备情况下如何避免主备循环复制?被删库跑路了如何正确恢复?(⊙o⊙)… 感觉越来越扯到DBA的活儿上去了。...适合: 1、原业务的 MySQL 的业务遇到单机容量或者性能瓶颈时,可以考虑使用 TiDB 无缝替换 MySQL。 2、大数据量下,MySQL 复杂查询很慢。

    62610

    MYSQL一次千万级表查询优化

    那么这SQL不优化直接第一次执行需要多久(这里强调第一次是因为MYSQL带有缓存功能,执行过一次的同样SQL,第二次会快很多。) ?...到此,避免临时表方法失败了,我们得从其他角度想想如何优化。 其实,9W的临时表并不算多,那么为什么导致会这么久的查询呢?我们想想这没优化的SQL的执行过程是怎么样的呢?...where条件过滤 5、执行group by分组语句 6、执行having 7、select列表 8、执行distinct去重复数据 9、执行order by字句 10、执行limit字句 这里得知,Mysql...我们进行内联查询前,最好能限制的表大小的条件都先用上了,同时尽量让条件查询和分组执行的表尽量小。感谢您们的阅读,如果有更好的方案,欢迎留言交流!!! 估计到这里,你猜这里就是全部的优化方案?...总结: 其实这个优化方案跟我上一篇文章MYSQL一次千万级表查询优化(一)解决原理一样,都是解决了内联表后数据就变得臃肿了,这时候再进行条件查询和分组就太吃亏了,于是我们可以先对单表进行条件处理,再进行表查询

    3.6K51

    顺丰快递:请签收MySQL灵魂十

    查询缓存:查询后的结果存储位置,MySQL8.0版本以后已经取消,因为查询缓存失效太频繁,得不偿失。 分析器:根据语法规则,判断你输入的这个SQL语句是否满足MySQL语法。...2、从节点开启一个线程(I/O Thread)把自己扮演成 mysql 的客户端,通过 mysql 协议,请求主节点的二进制日志文件中的事件 。...还可以延伸到由于主从配置不一样、主库大事务、从库压力过大、网络震荡等造成主备延迟,如何避免这个问题?主备切换的时候用可靠性优先原则还是可用性优先原则?如何判断主库Crash了?...互为主备情况下如何避免主备循环复制?被删库跑路了如何正确恢复?(⊙o⊙)… 感觉越来越扯到DBA的活儿上去了。...适合: 1、原业务的 MySQL 的业务遇到单机容量或者性能瓶颈时,可以考虑使用 TiDB 无缝替换 MySQL。 2、大数据量下,MySQL 复杂查询很慢。

    54440
    领券