iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >怎么在mysql中根据索引优化查询速度
  • 916
分享到

怎么在mysql中根据索引优化查询速度

2023-06-14 05:06:42 916人浏览 独家记忆
摘要

这篇文章将为大家详细讲解有关怎么在mysql中根据索引优化查询速度,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。(一)索引的作用索引通俗来讲就相当于书的目录,当我们根据条件查询的时候,没有索

这篇文章将为大家详细讲解有关怎么在mysql中根据索引优化查询速度,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

(一)索引的作用

索引通俗来讲就相当于书的目录,当我们根据条件查询的时候,没有索引,便需要全表扫描,数据量少还可以,一旦数据量超过百万甚至千万,一条查询sql执行往往需要几十秒甚至更多,5秒以上就已经让人难以忍受了。

(二)Mysql的索引类型:

mysql的索引有5种:主键索引、普通索引、唯一索引、全文索引、聚合索引(多列索引)。

唯一索引和全文索引用的很少,我们主要关注主键索引、普通索引和聚合索引。

1)主键索引:主键索引是加在主键上的索引,设置主键(primary key)的时候,mysql会自动创建主键索引;

2)普通索引:创建在非主键列上的索引;

3)聚合索引:创建在多列上的索引。

(三)索引的语法:

查看某张表的索引:show index from 表名;

创建普通索引:alter table 表名 add index  索引名 (加索引的列) 

创建聚合索引:alter table 表名 add index  索引名 (加索引的列1,加索引的列2) 

删除某张表的索引:drop index 索引名 on 表名;

(四)性能测试

测试环境:博主工作用台式机

处理器为Intel Core i5-4460 3.2GHz;

内存8G;

64位windows

1:创建一张测试表

DROP TABLE IF EXISTS `test_user`;CREATE TABLE `test_user` ( `id` bigint(20) PRIMARY key not null AUTO_INCREMENT, `username` varchar(11) DEFAULT NULL, `gender` varchar(2) DEFAULT NULL, `passWord` varchar(100) DEFAULT NULL) ENGINE=MyISAM DEFAULT CHARSET=utf8;

存储引擎使用MyISAM是因为此引擎没有事务,插入速度极快,方便我们快速插入千万条测试数据,等我们插完数据,再把存储类型修改为InnoDB。

2:使用存储过程插入1千万条数据

create procedure myproc() begin declare num int; set num=1; while num <= 10000000 do insert into test_user(username,gender,password) values(num,'保密',PASSWORD(num)); set num=num+1;end while; end
call myproc();

由于使用的MyISAM引擎,插入1千万条数据,仅耗时246秒,若是InnoDB引擎,就要花费数小时了。

然后将存储引擎修改回InnDB。使用如下命令:  alter table test_user engine=InnoDB;此命令执行时间大约耗时5分钟,耐心等待。

tips:这里是测试,生产环境中不要随意修改存储引擎,还有alter table 操作,会整张表,慎用。其次:myisam引擎没有事务,且只是将数据写到内存中,然后定期将数据刷出到磁盘上,因此突然断电的情况下,会导致数据丢失。而InnDB引擎,是将数据写入日志中,然后定期刷出到磁盘上,所以不怕突然断电等情况。因此在实际生产中能用InnDB则用。

3:sql测试

select id,username,gender,password from test_user where id=999999

耗时:0.114s。

因为我们建表的时候,将id设成了主键,所以执行此sql的时候,走了主键索引,查询速度才会如此之快。

我们再执行select id,username,gender,password from test_user where username='9000000'
耗时:4.613s。

我们给username列加上普通索引。

ALTER TABLE `test_user` ADD INDEX index_name(username) ;

此过程大约耗时 54.028s,建索引的过程会全表扫描,逐条建索引,当然慢了。

再来执行:selectid,username,gender,password from test_user where username='9000000'
耗时:0.043s。

再用username和password来联合查询

select id,username,gender,password from test_user where username='9000000' and `password`='*3A70E147E88D99888804E4D472410EFD9CD890AE'

此时虽然我们队username加了索引,但是password列未加索引,索引执行password筛选的时候,还是会全表扫描,因此此时

查询速度立马降了下来。

耗时:4.492s。

当我们的sql有多个列的筛选条件的时候,就需要对查询的多个列都加索引组成聚合索引:

加上聚合索引:ALTER TABLE `test_user` ADD INDEX index_uNIOn_name_password(username,password)
再来执行:

耗时:0.001s。

开篇也说过软件层面的优化一是合理加索引;二是优化执行慢的sql。此二者相辅相成,缺一不可,如果加了索引,还是查询很慢,这时候就要考虑是sql的问题了,优化sql。

Tips:

1:加了索引,依然全表扫描的可能情况有:

索引列为字符串,而没带引号;

索引列没出现在where条件后面;

索引列出现的位置没在前面。

2:关联查询不走索引的可能情况有:

关联的多张表的字符集不一样;

关联的字段的字符集不一样;

存储引擎不一样;

字段的长度不一样。

关于怎么在mysql中根据索引优化查询速度就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

您可能感兴趣的文档:

--结束END--

本文标题: 怎么在mysql中根据索引优化查询速度

本文链接: https://www.lsjlt.com/news/268028.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 怎么在mysql中根据索引优化查询速度
    这篇文章将为大家详细讲解有关怎么在mysql中根据索引优化查询速度,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。(一)索引的作用索引通俗来讲就相当于书的目录,当我们根据条件查询的时候,没有索...
    99+
    2023-06-14
  • mysql千万级数据量根据索引优化查询速度的实现
    (一)索引的作用 索引通俗来讲就相当于书的目录,当我们根据条件查询的时候,没有索引,便需要全表扫描,数据量少还可以,一旦数据量超过百万甚至千万,一条查询sql执行往往需要几十秒甚至更...
    99+
    2024-04-02
  • MySQL数据库中怎么优化索引查询
    这篇文章给大家介绍MySQL数据库中怎么优化索引查询,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。问题描述:我们要访问的表是一个非常大的表,四千万条记录,id是主键,program_i...
    99+
    2024-04-02
  • 索引:如何优化你的数据库查询速度?
    在现代的应用程序中,数据库是非常重要的一部分。然而,随着数据量的增长,查询速度的下降也会成为一个问题。这时候,索引就成为了一个非常重要的工具。在本文中,我们将介绍什么是索引,以及如何使用它来优化你的数据库查询速度。 什么是索引? 索引可以...
    99+
    2023-06-09
    异步编程 自然语言处理 索引
  • 如何通过索引优化提升PHP与MySQL的查询速度?
    摘要:在PHP与MySQL开发中,经常遇到查询速度慢的问题。本文将介绍如何通过使用索引优化提升查询速度,并提供具体的代码示例,帮助读者更好地理解和应用。引言:在网站开发过程中,查询数据库是非常常见的操作。然而,当数据量较大的时候,查询速度可...
    99+
    2023-10-21
    查询 优化 索引
  • SQL Server中怎么优化查询速度
    这期内容当中小编将会给大家带来有关SQL Server中怎么优化查询速度,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。  优化SQLServer查询速度的方法有哪些  1...
    99+
    2024-04-02
  • MySQL优化查询速度的方法
    这篇文章给大家分享的是有关MySQL优化查询速度的方法的内容。小编觉得挺实用的,因此分享给大家做个参考。一起跟随小编过来看看吧。如何选择优化的数据类型、如何高效的使用索引,这些对于高性能的MySQL来说是必...
    99+
    2024-04-02
  • 怎么在mysql中优化查询
    这篇文章给大家介绍怎么在mysql中优化查询,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。1、减少请求的数据量。只回到必要的列:最好不要使用SELECT*语言。只返回必要的行:使用LIMIT语言限制返回的数据。缓存重复...
    99+
    2023-06-15
  • MySQL数据库查询和索引的优化方式
    本篇内容主要讲解“MySQL数据库查询和索引的优化方式”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“MySQL数据库查询和索引的优化方式”吧!一、数据库查询性能...
    99+
    2024-04-02
  • 如何在Java中使用索引来优化大数据查询?
    Java是一种非常流行的编程语言,可以用来处理大数据。在处理大量数据时,优化查询速度非常重要。使用索引是提高查询速度的一种方法。本文将介绍如何在Java中使用索引来优化大数据查询。 索引的概念 索引是一种数据结构,用于加快数据的查询速度...
    99+
    2023-07-20
    leetcode 索引 大数据
  • Mysql数据库表中为什么有索引却没有提高查询速度
    背景 时间过得太快了,春节假期感觉光速般就结束了,转眼间就要继续搬砖上班了。紧接着很快就要进入金三银四的求职面试高峰期,程序猿小枫还没有找到令自己感到满意的工作。就算是在过年放假期间...
    99+
    2024-04-02
  • 数据库查询的速度优化是怎样的
    数据库查询的速度优化是怎样的,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。对于数据库查询的速度优化,关于数据...
    99+
    2024-04-02
  • mysql怎么使用索引查询数据
    要使用索引查询数据,可以按照以下步骤进行: 1、创建索引:首先,在需要加索引的列上创建索引。你可以通过使用CREATE INDEX语...
    99+
    2024-04-09
    mysql
  • MySQL中Like模糊查询速度太慢该怎么进行优化
    这篇文章主要介绍MySQL中Like模糊查询速度太慢该怎么进行优化,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!第一个思路建索引like %keyword 索引失效,使用全表扫描。like keyword% 索引有效...
    99+
    2023-06-22
  • 建立索引能提升表中数据查询的速度吗
    这篇文章将为大家详细讲解有关建立索引能提升表中数据查询的速度吗,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。首先明白为什么索引会增加速度,DB在执行一条Sql语句的时候,...
    99+
    2024-04-02
  • mysql索引怎么优化
    1. 使用合适的数据类型:选择合适的数据类型可以减小索引的大小,提高查询速度。例如,使用INT类型代替VARCHAR类型存储数字字段...
    99+
    2024-02-29
    mysql
  • MySQL explain根据查询计划去优化SQL语句
    本篇内容介绍了“MySQL explain根据查询计划去优化SQL语句”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!MySQL是一...
    99+
    2023-07-05
  • Mysql根据时间查询日期的优化技巧
    例如查询昨日新注册用户,写法有如下两种: EXPLAIN select * from chess_user u where DATE_FORMAT(u.register_time,'...
    99+
    2024-04-02
  • MySQL explain根据查询计划去优化SQL语句
    目录一、什么是mysql explain二、如何使用MySQL explainMySQL是一种常见的关系型数据库管理系统,常被用于各种应用程序中存储数据。当涉及到大量的数据时,数据库查询的性能就成了关键因素,这时就需要M...
    99+
    2023-04-07
    MySQL explain查询计划去优化SQL语句 explain优化SQL语句
  • 如何在MongoDB中实现数据的索引和查询优化功能
    如何在MongoDB中实现数据的索引和查询优化功能近年来,随着大数据的兴起,数据存储和查询变得越来越复杂。对于数据量较大的应用来说,索引和查询优化就成了至关重要的任务。MongoDB是一种非关系型数据库,由于其面向文档的特点,使得其在处理海...
    99+
    2023-10-22
    数据库性能 查询优化 MongoDB索引
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作