>데이터 베이스 >MySQL 튜토리얼 > 通过实例来理解MySQL索引

通过实例来理解MySQL索引

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB원래의
2016-06-07 16:48:081032검색

索引的使用首先建立库之后,并创建表,表结构如下:mysqlcreatedatabasetest1;QueryOK,0rowsaffected(0.01sec)mysqlusetest1;Databasechangedmysqlcreatetableyw

 

当一个表里有一个int索引,varchar索引, 一个查询会么用到那个索引?(是先用int索引还是varchar索引呢?)

涉及到索引查询成本的理解

例:

select * from tbwhere c1_int=xxx and c2_varchar=xxx;

同样存在idx_c1和idx_c2

假设来讲: 总体查询成本是1, 基于int查询0.6 基于varchar 是0.7

实际来说基于varchar的是0.7那么,对于mysql来讲是选择任何一个索引;

如果查询成本1,,那么其他两个都小于查询成本,那么都是可以的;

那么这时我们到底选择哪个完全取决于mysql的机制,mysql是按照先后的顺序进行选取

比如

create index varchar

首先创建varchar,那么,它会选择varchar,以此类推

所以,是根据其顺序进行选择的,也是mysql的机制

 

对其核心优化整体框架

核心概念: 减少IO

实际行动: 控制结果集大小,争取1秒内完成

减少IO,   考虑是否使用顺序IO

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.