对于web应用开发,多数性能瓶颈均出现在数据库上,除了采用分布式架构或云处理(大公司基本上都是),更重要的是平时程序设计时要遵照一些规则,从根本上提高系统的性能,以下总结了一些常用的规则方法,仅供参考,欢迎跟帖补充。。。 1、 把数据、日志、索引放到不同的I/O设备上,增加读取速度。数据量(尺寸)越大,提高I/O越重要。 2、 纵向、横向分割表,减少表的尺寸,如:可以把大数据量的字段拆分表。 3、 根据查询条件,建立索引,优化索引、优化访问方式,限制结果集的数据量。注意填充因子要适当(最好是使用默认值0)。索引应该尽量小,尽量使用字节数小的列建索引,不要对有限的几个值的列建单一索引。 4、
用OR的字句可以分解成多个查询,并且通过UNION链接多个查询。它们的速度只与是否使用索引有关,如果查询需要用到联合索引,用UNION all执行的效率更高。 5、 在查询SELECT语句中用WHERE子句限制返回的行数,避免表扫描。如果返回不必要的数据,则浪费了服务器的I/O资源,加重了网络的负担,降低了性能。如果表很大,在表扫描期间将表锁住,禁止其他的联结访问表,后果很严重。 6、 注意使用DISTINCT,在没有必要时不要用,它同UNION一样会使查询变慢。 7、 在IN后面值的列表中,将出现最频繁的值放在最前面,出现最少的放在最后面,减少判断的次数。 8、
一般在GROUP BY和HAVING子句之前就能剔除多余的行,所以尽量不要用它们来做剔除行的工作,也就是说尽可能在WHERE中过滤数据。 9、 尽量将数据的处理工作放在服务器上,减少网络的开销,如使用存储过程。存储过程是编译、优化过,并且被组织到一个执行规划里,且存储在数据库中的SQL语句(存储过程是数据库服务器端的一段程序),是控制流语言的集合,速度当然快。 10、不要在一句话里再三地使用相同的函数,浪费资源,将结果放在变量里再调用更快。 11、针对大量只读查询操作进行优化的方法:1)数据量小的数据,可以考虑不存储在数据库中,而是通过程序常量的方式解决。2)需要存储在数据库中的数据,可以考虑采用物化视图(索引视图)。当DBA在视图上创建索引时,这个视图就被物化(执行)了,并且结果集被永久地保存在唯一索引中,保存方式与一个有聚簇索引的表的保存方式相同。物化视图减除了为引用视图的查询动态建立结果集的开销,优化人员可以在查询中使用视图索引,而不需要在FROM子句中直接指定视图。3)数据存储时可以考虑适当的数据冗余,以减少数据库表之间的链接操作,提高查询效率。4)针对数据的特点,采取特定的索引类型。例如,位图索引等。 12、对于SQL语句书写时的一些建议:1)写语句时能够确定数据库对象所有者的,尽可能把所有者带上,如:SELECT
* FROM dbo.Users2)存储过程中,参数定义最好放在最前面,尽可能一次定义,如:DECLARE @USER_ID INT ,@USER_NAME VARCHAR(50) ,@PASSWORD VARCHAR(50)3)为参数赋值时,尽可能一次赋值,如:SELECT @USER_ID = 1001 ,@USER_NAME = 'xiaojun.liu'4)尽量少用游标
分享到:
相关推荐
### 大型关系型数据库优化探讨 #### 一、前言 Oracle数据库作为一种广泛应用的大型关系型数据库管理系统,在众多行业中扮演着至关重要的角色。然而,在实际应用过程中,由于多种因素的影响,Oracle数据库往往无法...
达梦数据库性能优化 达梦数据库作为国产数据库市场占有率第一的高性能、高可靠性、高安全性、高兼容性大型关系型数据库管理系统,已经成功替代了Oracle,在电力、金融、电子政务、教育等行业领域得到了广泛的应用,...
本文将详细探讨SQL检索优化的方法,并分析这些优化技术对关系型数据库性能提升的重要性和实际应用。 首先,SQL检索优化的必要性体现在其直接影响数据库信息查询效率的高低。在关系型数据库中,SQL语句的执行涉及到...
本文将深入探讨关系型数据库的工作原理及其优化策略,主要关注Oracle和MySql这两种主流数据库。 首先,我们要理解关系型数据库的基础——SQL(结构化查询语言)。SQL是用于操作关系数据库的标准语言,包括数据查询...
Oracle数据库作为业界广泛使用的大型关系型数据库管理系统,其性能优化对于企业的业务运行至关重要。这本书从硬件、软件以及实际应用的多个角度出发,系统地介绍了数据库性能优化的策略和技巧。 首先,硬件层面的...
Oracle数据库是全球广泛使用的大型企业级关系型数据库管理系统,它在处理复杂的数据操作和高并发事务处理方面表现出色。然而,随着数据量的增长和业务需求的增加,数据库性能优化成为了一个至关重要的任务。"Oracle...
Oracle数据库是全球广泛使用的大型关系型数据库管理系统之一,其性能优化是DBA(数据库管理员)和系统管理员关注的重要领域。盖国强先生的《Oracle数据库性能优化》一书深入浅出地探讨了这个主题,旨在帮助读者理解...
关系型数据库是现代软件开发中不可或缺的一部分,尤其是在Java应用程序中,常常通过JDBC(Java Database Connectivity)接口来实现数据存取。本资料“关系型数据库习题与解答”旨在帮助学习者深入理解和掌握关系型...
深入探讨了关系型数据库设计中的规范化、反规范化以及性能优化。文章首先介绍了关系型数据库的基本概念和特点,随后详细阐述了规范化的理论基础及其优点,如减少数据冗余和提高数据一致性。接着,讨论了反规范化的...
Oracle数据库是全球广泛使用的大型关系型数据库管理系统,其性能优化是一项关键任务,直接影响到系统的响应速度、资源利用率和整体稳定性。本合集包含了11个文档,全面涵盖了Oracle数据库性能优化的各种方面,旨在...
通过本教程的学习,你将能够理解关系型数据库的基本概念,掌握SQL语言,学会如何设计和优化数据库,以及处理并发和故障恢复等问题。此外,你还将了解到数据库管理系统如MySQL、Oracle、SQL Server等的使用,为实际...
《Lucene与关系型数据库对比:深度解析与应用探索》 在信息爆炸的时代,数据管理和检索成为了企业乃至个人日常工作中不可或缺的部分。随着技术的发展,不同的数据处理方式应运而生,其中Lucene与关系型数据库作为两...
非关系型数据库(NoSQL)是一种不同于传统的关系型数据库的数据存储模型。在信息化时代,随着大数据、云计算和互联网应用的快速发展,NoSQL数据库因其高可扩展性、高性能、灵活的数据模型等特点,逐渐受到广泛的关注...
阿里云分布式关系型数据库 DRDS 是一种云原生、分布式的关系型数据库,它提供了高性能、可扩展、安全可靠的数据存储和处理能力。为了帮助开发者更好地使用 DRDS,阿里云提供了 DRDS 最佳实践指南,旨在帮助开发者更...
### SQLServer数据库性能优化 #### 一、数据库性能优化的重要性 数据库系统作为现代企业管理和信息处理的核心组件,其性能直接影响到整个系统的响应速度和用户体验。SQL Server作为一种广泛使用的数据库管理系统,...
### 关系型数据库与第三代数据库的发展 #### 一、关系型数据库概述 1. **定义与历史背景**: - 关系型数据库是一种基于关系模型的数据库,该模型由E.F. Codd于1970年提出。关系模型通过表格形式组织数据,并通过...
《Oracle数据库性能优化实践指南》是一本专注于Oracle数据库性能调优的专业书籍,旨在帮助读者深入理解和掌握如何在实际环境中提升Oracle数据库的运行效率。Oracle数据库是全球广泛使用的大型企业级数据库管理系统,...
在实际应用中,为了优化性能,关系型数据库采用多种策略,如索引加速查询、缓存减少磁盘I/O、分区和分片提升大规模数据处理能力。同时,数据库管理员会进行定期维护,如数据备份、性能监控和调优,以保证系统的稳定...