mysql 优化(4)索引覆盖和最优索引
索引覆盖** 很重要的 一个概念 就是在索引上查找!!!
如果查询的列恰好是索引的一部分,那么查询只需要在索引文件上进行,不需要回行到磁盘再找数据.
这种查询速度非常快,称为”索引覆盖”
非聚促索引 索引文件对应了数据要回行 浪费掉了时间
索引和数据区别
索引是高效组织起来的树 , 节点 ,查找树叶 结构更优于数据
索引可以被导入内存中进行查询
索引本身数据结构简单 再放入内存 很快很快
。。。。。。。。。结果一回行 就满了。。。我擦。。。
所以呢 如果建立两条索引 index( uid , aid)
如果在索引树上已经覆盖了你想要的数据 如 select uid from msg where aid = 1
索引已经覆盖了想要查的 则直接在内存中的索引取出来 速度效率都非常快 自然不用回行查找
最优索引:
查询频繁,区分度高 ,长度小
尽量覆盖常用字段 , ------》索引覆盖
左前缀不易区分 逆转url 把内容到过来 ; 左前缀区分度大
伪哈希 crc32() 函数 来唯一区分 crc32('http://wwww.baidu.com');给urlcrc 建索引 而不是去给url 避免了索引
学会 explain 来查看效果 ;
伪hash索引效果
同时存 url_hash列
create table t10 ( id int primary key, url char(60) not null default '' );
insert into t10 values (1,'http://www.baidu.com'), (2,'http://www.sina.com'), (3,'http://www.sohu.com.cn'), (4,'http://www.onlinedown.net'), (5,'http://www.gov.cn'); alter table t10 add urlcrc int unsigned not null;
在sql存储时, crcurl== crc32(url),
因为crc的结果是32位int无符号数,因此当数据超过40亿,也会有重复,但这是值得的.
(索引长度为int4个字节)
多咧索引的设计
但从 商城的实际业务业务看, 顾客一般先选大分类->小分类->品牌,
最终选择 (1)index(cat_id,brand_id), + index(cat_id,shop_price)来建立索引
甚至可以再加 (3)index(cat_id,brand_id,shop_price),3个冗余索引 冗余字段 。。。
但(3)中的前2列和(1)中的前2列一样,再去掉(1)
index(cat_id,price) 和 index(cat_id,brand_id,shop_price); 也就是可以冗余 但是不能能重复 左前缀原则
以上就是mysql 优化(4)索引覆盖和最优索引的内容,更多相关内容请关注PHP中文网(www.php.cn)!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

如何通过MySQL对AVG函数优化来提高性能MySQL是一款流行的关系型数据库管理系统,其中包含了许多强大的函数以及功能。其中AVG函数被广泛使用在计算平均值的情形,但是由于这个函数需要遍历整个数据集,所以在大规模数据的情况下会导致性能问题。本文将详细介绍如何通过MySQL对AVG函数进行优化,从而提高性能。1.使用索引索引是MySQL优化中最重要的一部分,

MySQL是一种广泛应用于电子商务领域的关系型数据库管理系统。在电子商务应用中,对MySQL进行优化和安全工作是至关重要的。本文将解析MySQL在电子商务应用中的优化与安全项目经验。一、性能优化数据库架构设计:在电子商务应用中,数据库的设计是关键。合理的表结构设计和索引设计能够提高数据库的查询性能。同时,使用分表和分区技术可以减少单一表的数据量,提高查询效率

基于TokuDB引擎的MySQL优化:提升写入和压缩性能引言:MySQL作为一种常用的关系型数据库管理系统,在大数据时代的背景下,面临着越来越高的写入压力和存储需求。为了应对这一挑战,TokuDB引擎应运而生。本文将介绍如何利用TokuDB引擎来提升MySQL的写入性能和压缩性能。一、什么是TokuDB引擎?TokuDB引擎是一种面向大数据的、用于处理高写入

MySQL是一种广泛使用的关系型数据库管理系统,常用于Web应用程序的开发和数据存储。在实际应用中,对MySQL的底层优化尤为重要,其中SQL语句的高级优化是提升数据库性能的关键所在。本文将介绍实现MySQL底层优化的一些技巧和最佳实践,以及具体的代码示例。确定查询条件在编写SQL语句时,首先要明确定义查询条件,避免使用无限制的通配符查询,即避免使用"%"开

如何优化MySQL连接数管理MySQL是一种流行的关系型数据库管理系统,广泛应用于各种网站和应用程序中。在实际的应用过程中,MySQL连接数管理是一个非常重要的问题,尤其是在高并发情况下,合理管理连接数可以提高系统的性能和稳定性。本文将介绍如何优化MySQL连接数管理,包括详细的代码示例。一、理解连接数管理在MySQL中,连接数是指系统能够同时连

如何合理配置和优化MySQL的双写缓冲技术引言:MySQL的双写缓冲技术是一种提高数据安全性和性能的重要技术。本文将介绍如何合理配置和优化MySQL的双写缓冲技术,以便更好地保护数据,并提升数据库的性能。一、什么是双写缓冲技术双写缓冲技术是MySQL的一种I/O优化技术,它可以大幅减少磁盘I/O操作的次数,提高数据库的写入性能。当MySQL执行写入操作时,先

MySQL数据库作为一种常见的关系型数据库,随着数据库中数据量的增加和查询需求的变化,底层优化变得尤为重要。在进行MySQL底层优化的过程中,SQL语句优化是一项至关重要的工作。本文将讨论SQL语句优化的常见技巧和原则,并提供具体的代码示例。首先,SQL语句优化需要考虑以下几个方面:索引的优化、查询语句的优化、存储过程和触发器的优化等。在这些方面,我们将从具

MySQL是一种广泛使用的开源数据库管理系统,用于存储和管理大量数据。但是,使用MySQL时,您可能会遇到各种各样的问题,从简单的语法错误到更复杂的性能问题和故障。在本文中,我们将探讨一些最常见的MySQL问题和解决方法。连接问题连接问题很常见。如果您无法连接到MySQL服务器,请检查以下几点:1)MySQL服务器是否正在运行2)网络连接是否正常3)MySQ
