影响索引的mysql函数_mysql索引对排序的影响实例分析

本文实例讲述了mysql索引对排序的影响。分享给大家供大家参考,具体如下:

索引不仅能提高查询速度,还可以添加排序速度,如果order by 后面的语句用到了索引,那么将会提高排序的速度。

测试

1、创建测试表:t15表

CREATE TABLE `t15` (

`id` int(10) unsigned NOT NULL AUTO_INCREMENT,

`cat_id` int(10) unsigned NOT NULL DEFAULT '0',

`price` decimal(10,2) NOT NULL DEFAULT '0.00',

`name` char(5) NOT NULL DEFAULT '',

PRIMARY KEY (`id`),

) ENGINE=InnoDB DEFAULT CHARSET=utf8

2、插入1W行数据

$db = 'test';

$conn = mysql_connect('localhost','root','1234');

mysql_query('use ' . $db , $conn);

mysql_query('set names utf8' , $conn);

for($i=1;$i<=10000;$i++) {

$cat_id = rand(1,10);

$price = rand(1,50000);

$name = substr(str_shuffle('abcdefghjkmnpqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ234565789'),0,5);

$sql = sprintf("insert into t15 values (%d,%d,%f,'%s')",$i,$cat_id,$price,$name);

mysql_query($sql , $conn);

}

3、商场网站,一般都会按照某个分类进行价格上的排序,我们来模拟一下,执行同一条sql语句。

select name,cat_id,price from t15 where cat_id=1 order by price;

(1)首先不添加索引

从查询分析可以看到Extra中使用到了Using filesort,表示需要进行文件排序。

9f44ebabb97b4381addad1a789679e05.png

(2)给(cat_id,price)列添加索引

alter table t15 add index cp(cat_id,price);

这里的查询分析中Extra没用了Using filesort,表示添加上索引再进行查询的sql没有使用到外部排序,而是使用到了索引的排序,因为索引本身就是会排序的,所以不需要额外的order by一次。

19fae49ccd6f23c5bc0fc40fa1ec6dd8.png

4、观测查询时间

b29674489fa317b38538501182b123bb.png

Query_ID为1的是没有添加索引执行的语句,Query_ID为3的是添加索引后执行的语句,一个执行时间为0.013秒,一个执行时间为0.005秒,肯定是加上索引的快,我们来看看具体快在哪里

Query_ID为1的sql语句执行详细耗时图:

489edf890355748c00ed3be2c7c91b3d.png

Query_ID为3的sql语句执行详细耗时图:

c4c6f06971fe82a45c3873e9db3d0505.png

很明显,Query_ID1中的Sorting result耗时0.012秒,而Query_ID2中的Sorting result只耗时0.000004秒,而这个Sorting result就是排序耗时。

结论:索引对排序的速度是有一定的影响的,所以,在实际的开发中,要结合实际情况制定索引,并尽可能将排序字段添加至索引中。

更多关于MySQL相关内容感兴趣的读者可查看本站专题:《MySQL索引操作技巧汇总》、《MySQL常用函数大汇总》、《MySQL日志操作技巧大全》、《MySQL事务操作技巧汇总》、《MySQL存储过程技巧大全》及《MySQL数据库锁相关技巧汇总》

希望本文所述对大家MySQL数据库计有所帮助。

您可能感兴趣的文章:mysql建立高效的索引实例分析

mysql重复索引与冗余索引实例分析

mysql索引覆盖实例分析

MySQL中NULL对索引的影响深入讲解

详解MySQL索引原理以及优化

通过唯一索引S锁与X锁来了解MySQL死锁套路

mysql 添加索引 mysql 如何创建索引

MySQL索引类型总结和使用技巧以及注意事项

MySQL查看、创建和删除索引的方法

MySQL 创建索引(Create Index)的方法和语法结构及例子

mysql聚簇索引的页分裂原理实例分析

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/534244.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

php如何对 mysql 中text类型拆分存入一个数组_PHP递归实现无限级分类,可选返回字符串和数组...

正 文&#xff1a;在一些复杂的系统中&#xff0c;要求对信息栏目进行无限级的分类&#xff0c;以增强系统的灵活性。那么PHP是如何实现无限级分类的呢&#xff1f;我们在本文中使用递归算法并结合mysql数据表实现无限级分类。递归&#xff0c;简单的说就是一段程序代码的重复调…

python 开发框架 ant_Golang/python语言开发的分布式游戏服务器框架 mqant

软件介绍mqantmqant 是一款基于 Golang 语言的简洁&#xff0c;高效&#xff0c;高性能的分布式游戏服务器框架&#xff0c;研发的初衷是要实现一款能支持高并发&#xff0c;高性能&#xff0c;高实时性的游戏服务器框架&#xff0c;也希望 mqant 未来能够做即时通讯和物联网方…

java w3c xml_org.w3c.dom(java dom)解析XML文档

首先来了解点Java DOM 的 API:1.解析器工厂类&#xff1a;DocumentBuilderFactory创建的方法&#xff1a;DocumentBuilderFactory dbf DocumentBuilderFactory.newInstance();2.解析器&#xff1a;DocumentBuilder创建方法&#xff1a;通过解析器工厂类来获得 DocumentBuilder…

java中小数点位数_Java中限制小数位数问题

在Java中限制小数位数的方法不止一种&#xff0c;下面我们以限制两位小数为例来说明几种限制小数位数的方法&#xff0c;其他位数可以以此类推方式一&#xff1a;四舍五入double f 111231.5585;BigDecimal b new BigDecimal(f);double f1 b.setScale(2,…

orange pi java_[中文]Orange Pi家族各大成员一览表

全部复制来自官网&#xff0c;只修改了错别字和优化了排版。Orange Pi Zero香橙派Zero是一款开源的单板电脑&#xff0c;新一代的arm开发板,它可以运行Android4.4、Ubuntu、Debian等操作系统。香橙派Zero使用全志H2系统级芯片&#xff0c;同时拥有256MB/512MB DDR3 内存(256MB为…

java 微服务源码_基于Java的微服务架构源码案例Abixen

微服务越来越受欢迎&#xff0c;每个月都有更多的库包和解决方案来支持微服务的开发测试&#xff0c;很多Java开发人员虽然听说过微服务&#xff0c;但是真正采用还是有犹豫的&#xff1a;“我知道&#xff0c;微服务是非常棒的&#xff0c;微服务器更容易维护和进一步开发&…

rocketmq java例子_SpringBoot和RocketMQ的简单实例

1&#xff0c;引用jar包build.gradle文件添加jar包引用compile group: org.apache.rocketmq, name: rocketmq-spring-boot-starter, version: 2.1.12&#xff0c;配置文件application.properties 配置文件spring.application.nameapp-dempserver.port8081###rocketmq###rocketm…

mysql migrations_Code First Migrations更新数据库结构(数据迁移)

背景 code first起初当修改model后&#xff0c;要持久化至数据库中时&#xff0c;总要把原数据库给删除掉再创建(DropCreateDatabaseIfModelChanges)&#xff0c;此时就会产生一个问题&#xff0c;当我们的旧数据库中包含一些测试数据时&#xff0c;当持久化更新后&#xff0c;…

java 机器码 虚拟机_Java虚拟机:源码到机器码

无论什么语言写的代码&#xff0c;其到最后都是通过机器码运行的&#xff0c;无一例外。那么对于 Java 语言来说&#xff0c;其从源代码到机器码&#xff0c;这中间到底发生了什么呢&#xff1f;这就是今天我们要聊的。如下图所示&#xff0c;编译器可以分为&#xff1a;前端编…

docker 远程连接 文件看不到_开发提升十倍生产力: IDEA 远程一键部署 Spring Boot 到 Docker...

一、开发前准备二、新建项目《Java 2019 超神之路》《Dubbo 实现原理与源码解析 —— 精品合集》《Spring 实现原理与源码解析 —— 精品合集》《MyBatis 实现原理与源码解析 —— 精品合集》《Spring MVC 实现原理与源码解析 —— 精品合集》《Spring Boot 实现原理与源码解析…

java多台_Java 多态

Java中多态的特性&#xff0c;在学习中就是很难懂&#xff0c;比较抽象的概念。学的时候就犯糊涂&#xff0c;但日后会发现&#xff0c;基础在日常工作的理解中占有重要的角色。下面&#xff0c;我将用一个代码实例&#xff0c;回忆和巩固多态的概念和存在的意义。理解多态&…

快准牌电脑发软件_做自媒体必备技能,视频剪辑软件排名(精品篇)

作者&#xff1a;老马引流定位&#xff1a;专业专注引流推广0X00 前言毫不客气的说&#xff0c;视频正日益成为社交媒体和营销的重要组成部分&#xff0c;有越来越多的人参与到视频剪辑当中来&#xff0c;而其中最为关键的就是视频剪辑软件。而市面上的视频剪辑软件当然也是五花…

ad电阻原理图_【雕爷学编程】Arduino动手做(2)---光敏电阻模块

【Arduino】108种传感器模块系列实验&#xff08;02&#xff09;实验二&#xff1a;光敏电阻传感器模块我手里这块是三针版的&#xff0c;挺秀气吧光敏电阻是用硫化隔或硒化隔等半导体材料制成的特殊电阻器&#xff0c;其工作原理是基于内光电效应。光照愈强&#xff0c;阻值就…

java从url下载文件_Java从URL下载文件

在这篇文章中将学习如何从java下载URL中的文件。使用java.net.URL openStream()方法从java程序中的URL下载文件。也可以使用Java NIO Channels或Java IO InputStream从URL打开流中读取数据&#xff0c;然后将它保存到文件中。下面是从指定URL下载的简单Java程序。它演示了如何在…

怎么判断一个字符串的最长回文子串是否在头尾_LeetCode 第 131 号问题:分割回文串...

题目来源于 LeetCode 上第 131 号问题&#xff1a;分割回文串。题目难度为 Medium&#xff0c;目前通过率为 45.8% 。题目描述给定一个字符串 s&#xff0c;将 s 分割成一些子串&#xff0c;使每个子串都是回文串。返回 s 所有可能的分割方案。示例:输入题目解析首先&#xff0…

java的地位_Java地位无可动摇的12个原因

如今&#xff0c;面对曾经在程序员中被各种新技术掩盖直至堙灭的技术值得怀念。犹如COBOL这当年被老程序员们尊为神器的语言如今也基本没有价值。而Java作为现代程序员的中坚力量在这点上会不会成为下一个COBOL&#xff1f;有关JAVA的技术卖出多少本书已经是一个很久远的记忆了…

hystrix threadpool coresize_Hystrix断路器 - 求知若渴的蜗牛

Hystrix介绍在微服务场景中&#xff0c;通常会有很多层的服务调用。如果一个底层服务出现问题&#xff0c;故障会被向上传播给用户。我们需要一种机制&#xff0c;当底层服务不可用时&#xff0c;可以阻断故障的传播。这就是断路器的作用。他是系统服务稳定性的最后一重保障。在…

ionic保存到mysql_ionic sqlite 存取数据封装(兼容真机与webkit浏览器)

不管是真机还是H5&#xff0c;都有提供sqlite数据库进行存储数据。那么我们只要封装好函数就能随意调用了。如果只是存储简单的键值对形式的话&#xff0c;ionic官网也提供了一个兼容网页的storage&#xff0c;https://ionicframework.com/docs/storage&#xff0c;但只能key/v…

sql plus 表的总记录数是多少_直播回顾 | 亿级并发丝毫不虚,TDSQL-SQL引擎是如何炼成的...

腾讯云数据库国产数据库专题线上技术沙龙正在火热进行中&#xff0c;3月19日唐颢的分享已经结束&#xff0c;没来得及参与的小伙伴不用担心&#xff0c;以下就是直播的视频和文字回顾。关注“腾讯云数据库”公众号&#xff0c;回复“0319唐颢”&#xff0c;即可下载直播分享PPT…

java plug机制_插件机制 - OpooPress - 基于 Java 的静态博客生成器

插件机制通过插件机制可以很容易的扩展 OpooPress 博客系统的功能。 Plugin 定义如下public interface Plugin{/**** param registry*/void initialize(Registry registry);}Registry 接口定义如下&#xff1a;public interface Registry {Site getSite();void registerConvert…