MYSQL避免全表扫描「建议收藏」

MYSQL避免全表扫描「建议收藏」
MYSQL避免全表扫描 1.对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引 2.应尽量避免在 whe…

	MYSQL避免全表扫描[数据库教程]

MYSQL避免全表扫描

1.对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引

2.应尽量避免在 where 子句中对字段进行 null 值判断,否则将导致引擎放弃使用索引而进行全表扫描

如:select id from t where num is null可以在num上设置默认值0,确保表中num列没有null值,然后这样查询:select id from t where num=0

3.应尽量避免在 where 子句中使用!=或操作符,否则引擎将放弃使用索引而进行全表扫描。

4.应尽量避免在 where 子句中使用or 来连接条件,否则将导致引擎放弃使用索引而进行全表扫描,(可以使用union)

5.in 和 not in 也要慎用,否则会导致全表扫描(能用 between 就不要用 in)

6.下面的查询也将导致全表扫描。

select id from t where name like ‘%李%‘,select id from t where name like ‘%李‘

若要提高效率,可以使用此格式select id from t where name like ‘李%‘,也可以考虑全文检索。

7.避免在索引列上使用计算,也就是说,应尽量避免在 where 子句中对字段进行表达式操作和函数操作,这将导致引擎放弃使用索引而进行全表扫描。

如:select id from t where num/2=100应改为:select id from t where num=100*2

8.很多时候用 exists 代替 in 是一个好的选择:exists用于检查子查询是否至少会返回一行数据,该子查询实际上并不返回任何数据,而是返回值true或false。

select num from a where num in(select num from b)

用下面的语句替换:select num from a where exists (select 1 from b where num=a.num)

9.任何地方都不要使用 select from t ,用具体的字段列表代替“”,不要返回用不到的任何字段。

10.用>=替代>

高效: SELECT * FROM EMP WHERE DEPTNO >=4

低效: SELECT * FROM EMP WHERE DEPTNO >3

两者的区别在于, 前者DBMS将直接跳到第一个DEPT等于4的记录,而后者将首先定位到DEPTNO=3的记录并且向前扫描到第一个DEPT大于3的记录。

11.用Where子句替换having子句

MYSQL避免全表扫描

原文地址:https://www.cnblogs.com/duyuan/p/13605698.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/6689.html

(0)
上一篇 2023-04-05
下一篇 2023-04-05

相关推荐

  • 纪录片翻译价格_纪录片用英语翻译

    纪录片翻译价格_纪录片用英语翻译引言 Honeypot.io 自诩为欧洲最大的技术人才招聘平台,同时提供开发者视频网站,又被称其为 “开发者的 Netflix”。2022 年 1 月,该公司与 Red Hat、Google 和 CN

    2023-05-08
    137
  • MySQL日志简介「建议收藏」

    MySQL日志简介「建议收藏」一.MySQL日志简介 二.错误日志 作用: 记录mysql数据库的一般状态信息及报错信息,是我们对于数据库常规报错处理的常用日志。 默认位置: $MYSQL_HOME/data/ 开启方式: (My

    2022-12-18
    138
  • SqlServer 游标(一)[亲测有效]

    SqlServer 游标(一)[亲测有效]1.简述 在数据库中,游标是一个十分重要的概念。游标提供了一种对从表中检索出的数据进行操作的灵活手段,就本质而言,游标实际上是一种能从包括多条数据记录的结果集中每次提取一条记录的机制。游标总是与一条…

    2023-03-28
    158
  • 路由器哪个牌子的最好_路由器买哪家的好

    路由器哪个牌子的最好_路由器买哪家的好     作为一个离开网络几分钟就浑身不自在的资深网虫,我对网络环境的要求自然不低,相信很多小伙伴跟我一样,平时爱玩玩游戏,刷刷短视频什么的。那么路由器什么牌子好呢?今天想从个人使用角度谈一些经验。…

    2023-02-22
    140
  • 聊一聊 HBase 是如何写入数据的?「建议收藏」

    聊一聊 HBase 是如何写入数据的?「建议收藏」i,大家好,我是大D。今天继续了解下 HBase 是如何写入数据的,然后再讲解一下一个比较经典的面试题。

    2023-05-17
    146
  • 如何在CMD中运行Python文件

    如何在CMD中运行Python文件Python是一种强大的、易于上手的编程语言,它适用于开发各种类型的应用程序,从小型脚本到大型Web应用程序,以及科学和数学应用程序等领域。在Windows平台上,CMD(命令提示符)是一个强大的工具,可以帮助你在本地计算机上运行Python代码。本文将向你介绍如何在CMD中运行Python文件。

    2024-06-07
    46
  • activiti启动报错「建议收藏」

    activiti启动报错「建议收藏」1、activiti启动报错,检查如下表是否空:

    2023-02-19
    145
  • Python安装教程

    Python安装教程Python是一种高级编程语言,适用于各种场景,包括数据科学、网络编程、机器学习、人工智能等。Python在这些领域中的普及简化了编程,因此越来越多的人对它感兴趣。在本教程中,我们将提供Python的安装指南,以帮助你开始编写Python代码。

    2024-06-24
    46

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注