mysql中建立索引的目的是什么
数据库为什么要建索引?
数据库为什么要建索引?
在满足语句需求的情况下,尽量少的访问资源是数据库设计的重要原则,这和执行的 SQL 有直接的关系,索引问题又是 SQL 问题中出现频率最高的,常见的索引问题包括:无索引(失效)、隐式转换。1. SQL 执行流程看一个问题,在下面这个表 T 中,如果我要执行 需要执行几次树的搜索操作,会扫描多少行?
这分别是 ID 字段索引树、k 字段索引树。
数据库中的索引,原理是什么?为什么查询使用索引就会快?
数据库索引可以理解成图书馆的书架,书架按书目分类,或者理解成一本书的目录。想想如果没有这些目录,要找一本书中内容,就要从头把书翻一遍,或者把图书馆的书都找一遍,这样会有多慢?
数据库建立索引也是这个原理,数据有了分类目录了,查询数据的时候,先查找目录就会快了很多。
不过对现在的海量数据来讲,有了索引还是杯水车薪,查询依然很慢,而且建立索引要占用额外的存储空间,对数据库来讲存贮空间是非常值钱的,商业数据库存贮空间收费昂贵。
真正的海量数据存贮,查询效率都是用计算机硬件堆起来的,就是用钱堆起来的,不要想在软件上做点优化就会有多少本质的提高。
具体硬件优化有很多手段,前端查询,数据库缓存,分布式应用等等,要想掌握好数据库的优化,去看看实际的商业应用案例最好,书本上的那些东西,没多大意义。