通过与 Jira 对比,让您更全面了解 PingCode

  • 首页
  • 需求与产品管理
  • 项目管理
  • 测试与缺陷管理
  • 知识管理
  • 效能度量
        • 更多产品

          客户为中心的产品管理工具

          专业的软件研发项目管理工具

          简单易用的团队知识库管理

          可量化的研发效能度量工具

          测试用例维护与计划执行

          以团队为中心的协作沟通

          研发工作流自动化工具

          账号认证与安全管理工具

          Why PingCode
          为什么选择 PingCode ?

          6000+企业信赖之选,为研发团队降本增效

        • 行业解决方案
          先进制造(即将上线)
        • 解决方案1
        • 解决方案2
  • Jira替代方案

25人以下免费

目录

mysql中in大量数据导致查询速度慢怎么优化

mysql中in大量数据导致查询速度慢,优化的名列前茅种方案是拆分sql子查询,将一条sql拆为两条sql,将in内部的sql拆分出来,取出isbn集合列表,然后利用mybatis的sql拼接的功能,拼成完整的sql语句。

一、mysql中in大量数据导致查询速度慢怎么优化

拆分sql语句

mysql中in大量数据导致查询速度慢,优化的名列前茅种方案是拆分sql子查询,将一条sql拆为两条sql,将in内部的sql拆分出来,取出isbn集合列表,然后利用mybatis的sql拼接的功能,拼成完整的sql语句。

Xml代码如下所示,名列前茅步首先利用时间参数分页取出isbn列表

<select id=”findIsbnBetweenTime” >

    SELECT `isbn` FROM `tb_book_base` WHERE publish_time BETWEEN #{fromTime} AND #{toTime} LIMIT #{offset},#{size}

</select>

第二步先在服务层中判断上一轮取出的isbn列表是否为空,如果不为空继续向下执行,如果isbn集合列表不为空,继续利用mybatis提供的xml动态标签功能,拼接出in查询条件

<select id=”findBookMain” resultType=”com.lantian.db.model.BookMain”>

   SELECT * FROM `tb_book_main` WHERE `isbn` IN (

    <foreach collection=”list” item=”isbn” separator=”,”>

        #{isbn}

    </foreach>

   )

</select>

联结代替子查询

这种方案原理还是避免子查询,将子查询语句改写为联结查询,改写后的sql语句如下所示

SELECT

    t1.`isbn`,

    `code`

FROM

    tb_book_main t1

    INNER JOIN

    ( SELECT `isbn` FROM tb_book_base WHERE `publish_time` BETWEEN 20190903 AND 20191003 ) t2

on t1.`isbn` = t2.`isbn`

AND `role`= 100

limit 0,10

使用explain查看索引命中情况,mysql按照预期命中了tb_book_base的publish_time和tb_book_main的isbn索引

延伸阅读:

二、什么是Memory引擎

Memory引擎是Mysql的内存引擎,在实现上,Memory存储引擎不同于Innodb这种组织索引结构(索引即是数据,即数据存放在主键索引上),而是将索引和数据分开存储。索引采用Hash的形式,存放主键id和指向数据的指针,而数据则按插入顺序存放。我们称这种数据组织方式为堆组织方式。

相关文章