`

索引的注意

 
阅读更多
在选择索引时需要注意:
1.单行访问是很慢的.如果服务器从存储中读取一个数据块只是为了获取其中一行,那么就浪费了很多工作.最好读取的块中能包含尽可能多所需要的行.使用索引可以创建位置引用以提升效率

2.按顺序访问范围数据是很快的,如果服务器能够按需要顺序读取数据,那么就不再需要额外的排序操作,所以说经常需要排序的表可以考虑在插入时做好排序,以提升查询速度,这样GROUP BY查询也无须再做排序和将行按组进行聚合计算了

3.索引覆盖查询是很快的,如果一个索引包含了查询需要的所有列,那么存储引擎就不需要再回表查找行.这避免了大量的单行访问.

总的来说就是,编写查询语句时应该尽可能选择合适的索引以避免单行查找,尽可能地使用数据原生顺序从而避免额外的排序操作,并尽可能使用索引覆盖查询.

一般来说,建议按响应时间来对查询进行分析.找出那些消耗最长时间的查询或者那些给服务器带来最大压力的查询,然后检查这些查询的schema,sql,和索引结构,判断是否有查询扫描了太多的行,是否做了很多额外的排序或者使用了临时表,是否使用随机I/O访问数据,或者是否有太多回表查询那些不在索引的列的操作
分享到:
评论

相关推荐

    MYSQL索引注意事项及其优化

    MYSQL 索引注意事项及其优化 索引是 MySQL 中的一种数据结构,可以提高查询效率。但是,索引也需要合理地使用和优化,否则可能会降低查询效率。下面是 MySQL 索引的分类和优化注意事项。 索引分类 MySQL 中的索引...

    sqlserver2005 创建分区表 分区索引 注意事宜 分区索引

    【SQL Server 2005 创建分区表与分区索引详解】 分区表和分区索引是SQL Server 2005为企业级数据管理和性能优化提供的重要特性,尤其适用于处理大量数据的大型表。分区能够将数据划分为独立的、易于管理的块,这有...

    DB2索引及其优化(设计,优化,问题分析,解答,举例)

    DB2索引及其优化 DB2索引设计及其优化是...在本文中,我们讨论了DB2索引的概念、创建索引、建立索引注意事项、索引分类和索引优化等方面的知识点,并提供了一些有用的提示和建议,以帮助读者更好地理解和应用DB2索引。

    漫谈数据库索引漫谈数据库索引漫谈数据库索引

    总的来说,数据库索引是数据库性能优化的关键要素,合理使用和设计索引可以显著提升查询效率,但同时也要注意索引维护的额外成本,因为它会影响数据的插入、更新和删除速度。因此,在数据库设计时,需要权衡查询性能...

    创建索引和调优索引

    重命名索引则有助于管理和理解数据库结构,但需要注意索引名称的唯一性,不能与表的主键或唯一性约束同名。 复合索引,是建立在两个或更多列上的索引,它可以提高某些特定查询的性能,减少索引数量。然而,复合索引...

    oracle在线创建索引和重组索引

    Oracle 在线创建索引和重组索引 Oracle 在线创建索引和重组索引是数据库管理...在线创建索引和重组索引可以提高查询性能和减少索引的碎片化和空间浪费,但需要注意一些问题和评估索引的必要性和可能对现有语句的影响。

    MongoDB中创建索引需要注意的事项

    以下是一些在 MongoDB 中创建索引需要注意的重要事项: 1. **前台与后台创建索引**: - 前台创建索引(`--foreground`)会阻塞所有其他数据库操作,直到索引构建完成。这种方式适用于小型集合,因为它们不会占用太...

    MYSQL索引建立需要注意以下几点细节

    以下是对创建MySQL索引时需要注意的一些重要细节的深入解析: 1. **建立索引的时机**:索引应当在那些频繁出现在查询条件、排序或分组中的字段上创建。例如,如果一个字段经常用于`SELECT`查询的`WHERE`子句,那么...

    SQL Server 索引中include的魅力(具有包含性列的索引)

    SQL Server 索引中 include 的魅力(具有包含性列的索引) SQL Server 索引中 include 的魅力(具有包含性列的索引)是指在非聚集索引中添加非键列,以扩展索引的功能,...但是,需要注意在设计索引时的准则和限制。

    数据库索引那些事(数据库索引原理)

    "数据库索引那些事(数据库索引原理)" 数据库索引是数据库的一种对象,它保存数据库...数据库索引是数据库查询性能优化的重要手段,它可以提高查询速度、减少 I/O 操作,但是也需要注意索引的使用注意事项和优缺点。

    oracle约束和索引笔记

    **使用和维护索引的注意事项:** - 索引会占用额外的存储空间,并且在插入、删除和更新数据时需要维护,这可能会降低写操作的性能。 - 不是所有查询都受益于索引,对于全表扫描或者不使用索引列的查询,索引可能...

    V1.0-sqlServer索引使用总结.docx

    本文档总结了 SQL Server 中索引的使用方法、分类和注意事项,并提供了实践测试的示例代码。 索引的使用目的 索引的使用目的主要是为了提高查询速度和效率。通过创建索引,可以快速地定位到所需的数据,从而减少...

    Mysql数据库索引创建、索引删除、索引失效场景详解

    但是,需要注意的是,如果索引与主键关联,必须先删除主键,再删除主键索引。 索引的失效场景包括:更新或删除索引列,使用不带索引的全表扫描操作,使用`SELECT *`而不是明确列出索引列,使用`NOT IN`、`<> ALL()`...

    oracle索引陷阱,要注意的地方

    oracle索引陷阱,比较精深的oracle索引的用法,要注意的

    视图上使用索引的一个注意点

    ### 视图上使用索引的一个注意点 在数据库管理中,索引是提高查询效率的重要工具之一。然而,在实际应用中,特别是在涉及到视图(View)时,开发者经常会遇到索引建立后却没有被有效利用的情况。本文将通过一个具体...

    labview中的数组索引详细讲解

    在使用自动索引功能时,需要注意以下几点: * 在 For 循环中,默认启用自动索引功能。 * 在 While 循环中,默认关闭自动索引功能。 * 如果你只想要把一个单一的变量从 For 循环中传送出来,那么你就需要在循环结构...

    oracle的索引学习

    若需删除部分数据,应使用`DELETE`,但要注意其对索引的影响。 为了分析SQL查询的执行效率,Oracle提供了多种工具,如Autotrace和DBMS_XPLAN包。Autotrace可以方便地显示执行计划和统计信息,通过设置不同的参数,...

    MySQL-数据库-索引详解

    MySQL 数据库索引详解 MySQL 数据库索引是一种特殊的数据库结构,可以快速查询数据库表中特定记录。索引是提高数据库性能的重要方式。...注意添加索引的长度必须小于建表时给字段定义的长度,也可以不给长度。

Global site tag (gtag.js) - Google Analytics