`

影响数据库查询效率的因素搜集

阅读更多
1. Watermark 效应。 当一个数据库运行很长时间(几个月,几年)表中的记录被反复的修改和删除后,大量的磁盘空间没有被回收, 外在的表现就是表占用的空间越来越大, 当需要执行全表扫描的查询时,出现查询缓慢的症状。

2. BLOB, CLOB字段的滥用。 两个表,一个有LOB类型的列,一个没有, 其中记录的条数都一样, 索引也一样, 那么查询数据一样嘛?  答案时否定的, 即使你没有查询LOB字段里面的内容, 有LOB类型的表也会比较慢。 这个在淘宝团队里面时做过验证的, 他们曾经使用的解决办法是把LOB字段单独提出来放在另外一张表里面。


3. 调整操作系统参数,例如:运行在UNIX操作系统上的ORACLE数据库,可以调整UNIX数据缓冲池的大小,每个进程所能使用的内存大小等参数。



其他常见的原因

1. 没有索引或者没有用到索引 数据库索引就像书籍中目录一样,使用户在访问数据库数据时,不必遍历所有数据就可以找到需要的数据。创建索引后,可以保证每行数据的唯一性,极大地提高数据检索效率,这是一中牺牲空间换取性能的方法。没有索引或者没有用到索引是数据访问速度慢最常见的因素,也是程序设计的一个缺陷所在。

2. I/O吞吐量小,形成了瓶颈效应 I/O吞吐量是影响数据访问速度的客观因素(硬件因素)。在一定的硬件环境下,利用优化的部署方案可适当提高I/O吞吐量。

3. 没有创建计算列导致查询不优化 计算列是一个比较特殊的列,不填写任何设计类型,用户不可以改变该列的值。计算列的值是通过一定的函数公式等以另一个或多个列的值为输入值计算出的结果。如果没相应的计算列,在一些数据查询的时候需要对已有数据进行计算,从而浪费一部分性能。

4. 内存不足 对数据库数据的查询访问毫无疑问会占用大量的内存空间,当内存不足的情况下,数据的访问速度会受到明显的影响甚至访问出现超时情况,是影响数据访问速度的客观因素。

5. 网络速度慢 网络速度慢是影响数据访问速度的客观因素。可通过提高网络访问的位宽来解决。

6. 查询出的数据量过大 当查询出的数据量过大时,内存的占用、系统时间的占用等都影响数据访问的速度。可以采用多次查询、定位查询、和查询数据量控制来解决。

7. 锁或者死锁 锁或者死锁在数据库数据访问时会造成访问者等待时间过程或者永久无法获取到资源。这是查询慢最常见的因素之一,是程序设计的缺陷,要尽量避免。

8. 返回不必要的行和列 在一般的数据查询中,都尽可能多的获取数据信息,这样造成了不必要的数据遍历,大大的增加了数据访问的响应的时间。所以在一般的查询中,尽量查询少的行和列,将数据遍历时间降到最低以满足数据输出需求。

9. 查询语句不够优化 在数据查询访问过程中,使用最频繁的是使用自定义的查询语句进行数据输出的。所以编写优化的查询语句能够很大程度上提高数据查询访问的速度。
性能优化 数据库性能优化主要是提高数据访问的速度,即提高数据库响应速度的性能指标。性能优化主要分为主观因素和客观因素两部分的优化。这里主要针对影响性能的客观因素进行优化。
分享到:
评论

相关推荐

    影响网络信息检索效率的因素

    ### 影响网络信息检索效率的因素 #### 一、网络信息检索工具 ##### 1.1 网络检索工具的构成与工作原理 - **构成要素**:网络检索工具通常由三个主要部分组成——自动索引程序(Robot)、数据库以及检索软件。自动...

    提高Java数据库访问效率的策略研究.zip

    在Java开发中,数据库访问是应用性能的关键因素之一。优化这一环节可以显著提升系统的响应速度,减少资源消耗,从而提供更好的用户体验。本文将探讨几种提高Java数据库访问效率的策略,帮助开发者实现更高效的数据库...

    达梦数据库的性能优化收集.pdf

    达梦数据库性能优化 ...达梦数据库的性能优化需要考虑到多方面的因素,包括数据库参数、系统缓冲区、磁盘 I/O 瓶颈等,通过科学的分析和优化,可以提高数据库的性能和并发效率,满足不同应用场景的需求。

    数据库优化查询文档

    4. **存储优化**:存储配置对查询效率有很大影响。例如,选择正确的存储引擎(InnoDB、MyISAM等),调整内存缓冲池大小,以及优化数据文件的物理组织方式。 5. **统计信息与成本估算**:数据库会维护表和索引的统计...

    Oracle数据库查询调优

    - **选择性和基数估计**:影响查询优化的重要因素。 - **谓词处理和查询转换**:如何优化条件处理逻辑。 - **连接顺序和类型**:不同连接方法对性能的影响。 #### 九、反馈与建议 - **发送反馈**:向Oracle官方...

    巧用执行计划优化SQL Server数据库查询.pdf

    例如,对比全表扫描和使用索引的查询效率,可以明显看出索引对查询性能的影响。 总的来说,理解DBMS处理查询计划的过程,学会检索和分析执行计划,以及如何利用这些信息优化查询,是提升SQL Server数据库性能的关键...

    基于Oracle数据库查询优化策略的研究.pdf

    临时表的建立也是影响查询性能的因素。在处理大量数据时,临时表可以帮助分解复杂操作,但过度使用或不恰当使用可能导致内存资源的浪费。合理使用并及时清理临时表能保持系统运行的高效。 最后,统计信息的更新对...

    提高公共图书馆数据库采购效率的措施研究.docx

    ### 提高公共图书馆数据库采购效率的关键措施 #### 一、引言 随着信息技术的快速发展,公共图书馆的角色也在逐渐转变,从传统的纸质书籍借阅服务转向数字化信息服务。数据库作为现代图书馆的核心资源之一,对于...

    数据库的查询优化

    在数据库管理系统(DBMS)中,查询优化是一项至关重要的技术,它直接影响着查询的执行效率和资源消耗。Oracle9i作为一款成熟且强大的数据库软件,其查询优化功能尤其突出。查询优化程序是Oracle9i中的关键组件,它能够...

    基于Oralce数据库SQL查询优化研究.pdf

    Oracle数据库作为目前应用最广泛的大型数据库之一,其查询性能对于系统的整体运行效率至关重要。随着数据量的增加,如何提升数据库的查询性能成为了亟待解决的问题。针对这一问题,通过优化SQL语句,可以显著提升...

    数据库原理自考试题收集

    这涉及到索引设计、查询优化、存储优化和数据库重构等方面,通过调整这些因素,可以显著提升数据库的读写速度和响应时间。 以上知识点涵盖了数据库原理自考的主要内容,考生可以通过分析历年试题,如提供的压缩包内...

    数据库性能问题定位

    这可能包括但不限于:查询效率低下、索引设计不合理、数据冗余、存储空间不足、硬件资源限制、并发控制冲突以及数据库配置不当等。每个因素都可能成为性能瓶颈,因此定位问题的关键在于全面而深入的分析。 1. **...

    数据库课程设计指导教程 包括各步骤的详细解释说明

    这一步需要考虑查询效率、存储空间和并发访问等因素。 5. 数据库实施:在选定的DBMS上创建数据库,编写SQL语句来定义表、视图、索引等数据库对象。同时,要编写存储过程、触发器等数据库程序,以实现特定的业务逻辑...

    MySQL数据库调优技术大全

    - **CPU**:包括核心数量、频率等因素会影响数据库性能。 - **内存**:增加内存容量并使用64位系统可以提高缓存效率。 - **I/O**:磁盘读写速度直接影响到数据库性能。 - **网络**:高带宽和优化的传输协议可以...

    Oracle数据库性能优化实践指南

    2. **SQL优化**:SQL语句的执行效率直接影响数据库性能。优化SQL包括选择合适的索引、避免全表扫描、减少JOIN操作、合理使用子查询和临时表等。理解执行计划和EXPLAIN PLAN工具的使用是SQL优化的关键。 3. **索引...

    数据库课程设计 学生宿舍管理系统数据库设计

    1. 数据库设计的重要性:数据库设计是数据库系统的核心部分,直接影响着数据库的性能和安全性。 2. 学生宿舍管理系统的需求分析:需求分析是系统开发的首要阶段,需要确定系统的目标和任务,进行需求分析和需求收集...

    数据库性能测试报告.doc

    描述测试所用的硬件配置(CPU、内存、硬盘等)、操作系统、数据库版本和其他相关软件,以及网络环境,这些因素都可能影响到数据库的性能。 6. **测试指标** 明确测试关注的关键性能指标,如查询速度、数据处理...

    Oracle数据库性能的优化设计思路研究 (1).pdf

    本文将从Oracle数据库的基本概念、影响性能的主要因素以及相应的优化策略三个方面进行深入探讨。 1. Oracle数据库基础 Oracle数据库是全球广泛使用的高级关系型数据库管理系统,以其强大的数据管理能力、高并发性和...

Global site tag (gtag.js) - Google Analytics