`
shinepaopao
  • 浏览: 145228 次
社区版块
存档分类
最新评论

数据库优化的最佳实践

阅读更多
1)谨慎而有效地使用索引
  选择合理的索引(前缀性及可选性)、删除没有用的索引。
  2)使用规范化,但不要使用过头
  规范化(至少是第三范式)是一个易于理解且标准的方法。然而,在有些情况下,你可能希望违反这些规则。查询表通常是规范化的产物,也就是说,你创建了一个特殊的表,这个表包含了在其他表中被频繁使用的相关信息的列表。然而,当使用那些经常被访问且分布有限(仅有或有限的行数拥有小值)的查找表时,会使系统性能降低。在这种情况下,每次你使用查询信息,它们必须使用join以获取完整数据。join的开销很大,而且频繁访问会使开销随着时间逐渐增加。为了减少这种潜在的性能问题,可以使用枚举字段存储数据,而不是使用查找表存储数据。例如,可以使用枚举字段存储头发彩色值,而不是创建表来存储头发颜色值,这样还可以避免使用join.
  3)使用正确的存储引擎
  mysql的最强大的功能之一是它支持不同的存储引擎,存储引擎管理如何存储和恢复数据。mysql支持多个存储引擎,每个存储引擎具有独特的功能和用途,可以使数据库设计通过使用最合适他们的应用程序的存储引擎来改善数据库系统的性能。例如,如果有一个这样的环境:使用事务控制高度活跃的数据库,请选择一个合适这个情况的存储引擎(mysql的有些存储引擎不支持事务),你还可能会发现这样的视图和表,它们常常被查询但是几乎不被更新(例如查找表),在这种情况下,你可能希望使用存储引擎将这些数据存储在内存中,以便快速访问它们。
  InnoDB存储引擎支持事务,在需要事务支持时,通常应该选择这个存储引擎,它是Mysql中目前唯一事务性的引擎。很多第三方存储引擎支持事务,但是仅有InnoDB有"开包即用"选项。有趣的是,InnoDB中所有的索引都是B-trees,在这个B树中索引记录被存储在树的叶子项,InnoDB适用于高性能和事务处理环境。
  MyISAM存储引擎是Mysql默认引擎,如果你在create语句中省略了engine选项,那么默认使用这个引擎。MyISAM经常在数据仓库、电子商务和企业应用中使用。MyISAM使用高级缓存和索引机制提高数据检索速度,另外,当各种应用程序需要快速检索数据而不需要事务时,MyISAM将是很好的选择。
  Blackhole存储引擎是非常有趣的,它并不存储任何东西。实际上,正如它的名字所言-存储进去的数据永远还会返回。Blackhole存储引擎有个特殊的用途,如果启用了二进制日志SQL命令将被写入这个日志,这时,Blackhole存储引擎被当做复制拓扑中的中继代理使用。
  Memory存储引擎(有时被称为HEAP)是内存中的存储器,它使用哈希机制频繁检索被使用过的数据,这样可以更快地检索,它访问数据的方式与其他存储引擎类似,但是数据存储在内存中,并且只在mysql会话有效。当关机时,这些数据被刷新并删除掉。Memory存储引擎通常用于以下情况:静态数据被频繁使用且很少被改变(如查找表).
  4)通过Query Cache使用视图来加速结果
  5)使用约束
  6)使用explain、analyze、optimize
  这些工具在诊断和调优时很重要,在不发生错误的前提下经常使用它们,但是请小心使用。具体来说,当analyze、optimize有意义且不是作为定期的预定的事件时使用它们。我们发现有些系统管理员晚上使用这些命令,但是一般情况下,这样做是不值得的,并且会产生不必要的表副本。显然,强制系统定期复制数据浪费时间,并会导致操作过程中的访问有限。
10
9
分享到:
评论
3 楼 一个java程序员 2013-12-30  
freezingsky 写道
最近刚到一个公司,好不容易与北京开发组的一个项目经理沟通一下,那哥们说一句让我很无语的话:用mysql的系统,那系统得多小啊!
我直接一听,都无语了!

他可以洗洗睡了
2 楼 jahu 2013-12-30  
 MyISAM存储引擎是Mysql默认引擎,如果你在create语句中省略了engine选项,那么默认使用这个引擎。MyISAM经常在数据仓库、电子商务和企业应用中使用。MyISAM使用高级缓存和索引机制提高数据检索速度,另外,当各种应用程序需要快速检索数据而不需要事务时,MyISAM将是很好的选择。

          myisam 索引,和告诉缓存,,,能提高。能吗?
1 楼 freezingsky 2013-12-29  
最近刚到一个公司,好不容易与北京开发组的一个项目经理沟通一下,那哥们说一句让我很无语的话:用mysql的系统,那系统得多小啊!
我直接一听,都无语了!

相关推荐

    数据库优化最佳实践.pptx

    本文件"数据库优化最佳实践.pptx"主要涵盖了优化的思路、实践案例以及总结,以下是对这些内容的详细解读。 一、介绍 在介绍部分,提到了几种常见的数据库和服务类型,包括MCQ(可能是Message Queue,消息队列)、...

    2013Oracle技术嘉年华演讲PPTの数据库优化最佳实践

    2013Oracle技术嘉年华演讲PPTの数据库优化最佳实践,内附:(1)Jonathan_beijing_histograms_12c.pdf(2)Tim_RDBMS Forensics Troubleshooting Using ASH.pdf(3)崔华_Oracle数据库优化器探秘.pdf(4)盖国强_...

    DB2数据库管理最佳实践笔记-10日常运维.pdf

    DB2数据库管理最佳实践主要关注的是数据库的日常运维,其中包括了收集统计信息、重组操作以及相关的维护工具。这里我们将深入探讨这些关键知识点。 1. **Runstats**:Runstats是DB2数据库管理系统中的一个重要工具...

    20个数据库设计最佳实践

    ### 数据库设计最佳实践 #### 1. 使用明确、统一的命名规则 - **实践要点**:为了确保数据库的一致性和可读性,应采用一套明确的命名规则。例如,表名可以使用如`School`、`SchoolCourse`、`CourseID`这样的命名...

    DB2数据库管理最佳实践pdf

    DB2数据库管理最佳实践是IBM公司推出的一款关系型数据库管理系统,广泛应用于企业级的数据存储、管理和分析。这份PDF文档很可能是对DB2数据库在实际操作中的优化策略、配置技巧和故障排查方法的深入探讨,旨在帮助...

    Oracle 数据库性能优化与运维最佳实践

    "Oracle数据库性能优化与运维最佳实践"的主题涵盖了如何确保Oracle数据库高效、稳定运行的关键技术和策略。 首先,性能优化涉及多个层面,包括SQL查询优化、存储结构优化、索引设计以及数据库参数调整。SQL查询优化...

    Greenplum 数据库最佳实践

    Greenplum数据库是一种基于MPP(大规模并行处理)架构的关系型数据库,专为数据仓库和大数据...通过实施这些最佳实践,可以确保数据库集群的稳定运行,提升查询性能,优化资源利用,同时也能快速应对业务扩展的需求。

    Oracle数据库诊断最佳实践指南.pptx

    本篇"Oracle数据库诊断最佳实践指南"主要涵盖了Oracle日常维护中可能遇到的风险、升级12c后的常见问题以及一些案例分析。以下是对这些知识点的详细解释: 1. **Oracle日常维护风险**: - **CPU扩容**:当不同节点...

    DB2数据库管理最佳实践笔记-10日常运维 (2).pdf

    【DB2数据库管理最佳实践】 在DB2数据库管理系统中,保持数据库的良好运行状态至关重要,这涉及到一系列的日常运维任务。本文主要围绕两个关键工具——Runstats和Reorg,以及它们在提升DB2性能中的作用进行深入讲解...

    深入优化DB2数据库的最佳实践

    总的来说,深入优化DB2数据库的最佳实践包括但不限于:保持统计信息的准确性和时效性,充分利用阶段1和阶段2的谓词处理,以及适时进行查询重写。通过这些方法,可以显著提升DB2数据库的性能,减少响应时间,提高系统...

    数据库设计最佳实践:如何规划和优化你的数据库结构.md

    数据库设计的最佳实践,重点介绍了如何规划和优化数据库结构以实现高效、安全和可扩展的数据库系统。文章首先强调了数据库设计的重要性,包括数据完整性、性能优化、可维护性、扩展性和安全性。接着,涵盖了从需求...

    最佳实践之一数据库性能优化

    #### 三、Oracle数据库性能优化最佳实践 为了应对上述挑战,我们可以采用以下几种Oracle数据库性能优化策略: 1. **Oracle Enterprise Manager (OEM)的使用** - **简介**:Oracle Enterprise Manager是Oracle提供...

    MySQL数据库结构优化最佳实践

    详细介绍数据库结构设计、范式和反范式设计、物理设计等等 目录: 一、结构优化概述 二、结构设计 三、需求分析及逻辑设计 四、需求分析及逻辑设计—反范式化设计 五、范式化设计和反范式化设计优缺点 六、物理设计...

    VMware 部署 Oracle 数据库 - 最佳实践指南

    本文档为在VMware vSphere上部署Oracle数据库提供了全面的指南,涵盖了从硬件配置到软件优化的最佳实践。遵循这些建议可以帮助企业充分利用虚拟化的优势,同时保持数据库的高性能和稳定性。 #### 十、参考文献 - ...

    数据库性能优化最佳实践.pptx

    ### 数据库性能优化最佳实践 #### 一、数据库性能评估 **1.1 概述** 数据库性能评估是确保数据库高效稳定运行的关键步骤。通过对数据库性能的全面评估,可以识别出潜在的问题点,并据此制定相应的优化策略。评估...

    数据库相关最佳实践

    在设计和管理数据库时,遵循最佳实践至关重要,这将确保系统的性能、安全性和可维护性。以下是一些关于数据库相关最佳实践的详细说明: 1. **合理规划数据库架构**: - 分离读写操作:通过主从复制或者读写分离...

    阿里云分布式关系型数据库DRDS-最佳实践-D.docx

    阿里云分布式关系型数据库 DRDS 最佳实践 阿里云分布式关系型数据库 DRDS 是一种云原生、分布式的关系型数据库,它提供了高性能、可扩展、安全可靠的数据存储和处理能力。为了帮助开发者更好地使用 DRDS,阿里云...

    SQL数据库优化工具

    在IT领域,数据库是存储和管理数据的核心组件,而SQL(Structured ...对于"WebCast20050127_Demo"这个文件,可能是一个关于数据库优化工具的演示或教程,进一步深入学习和实践,将有助于我们更好地理解和应用这些工具。

    数据库性能优化:策略、技术与最佳实践

    本文将深入探讨数据库性能优化的策略、技术方法和最佳实践。 数据库性能优化是一个持续的过程,涉及到多个层面的优化策略和技术方法。通过索引优化、查询优化、配置调整、硬件升级、系统资源管理、并发控制、缓存...

    Oracle 19c参数设置最佳实践 .xlsx

    oracle 19c数据库参数优化最佳实践

Global site tag (gtag.js) - Google Analytics