最近的工作中进行了几个SQL优化,对索引也有了一些新的认识。
什么是索引?
百度百科是这么说的:
在关系数据库中,索引是一种单独的、物理的对数据库表中一列或多列的值进行排序的一种存储结构,它是某个表中一列或若干列值的集合和相应的指向表中物理标识这些值的数据页的逻辑指针清单。索引的作用相当于图书的目录,可以根据目录中的页码快速找到所需的内容。
索引提供指向存储在表的指定列中的数据值的指针,然后根据您指定的排序顺序对这些指针排序。数据库使用索引以找到特定值,然后顺指针找到包含该值的行。这样可以使对应于表的SQL语句执行得更快,可快速访问数据库表中的特定信息。
和索引密切相关的一个概念叫全表扫描:
在数据库中,对无索引的表进行查询一般称为全表扫描。全表扫描是数据库服务器用来搜寻表的每一条记录的过程,直到所有符合给定条件的记录返回为止。
有了以上两个概念我们就知道索引是干什么的,有没有索引的差别了。
没有索引有那么夸张吗?
诡异的异常引出的问题
这是一个查询请求数据库拒绝连接的异常
然而,通过排查查询本身只是个简单到不能再简单的单表查询。这个问题通过百度查询 也只会查到某些配