有什么好的资源可以帮助您理解主要引擎上的数据库调优并提高您在该领域的知识?

这个问题的想法是收集始终存在的资源,这样人们就可以有一个“一站式”的好知识商店,同行认可的资源。


通用SQL

本书:SQL性能调优 书籍:SQL调优 书:SQL的艺术 书:重构SQL应用程序 书籍:数据库调优:原理、实验和故障排除技术 使用索引,卢克!—面向开发人员的数据库性能指南

PostgreSQL (wiki)

性能优化 快速PostgreSQL优化 解释分析解释器 PostgreSQL性能提示 本书:PostgreSQL 9.0高性能

MySQL

MySQL的隐藏特性 书籍:高性能MySQL /博客:高性能MySQL 博客:Xaprb (MySQL dba)

甲骨文

如何在StackOverflow上询问Oracle调优问题 如何解释查询的解释计划? Oracle高级调优脚本 Oracle数据库性能调优指南 问汤姆 Oracle数据库SQL参考 书籍:了解Oracle性能 书籍:优化Oracle性能 书籍:解决Oracle性能问题 本书:基于成本的Oracle基础知识

MS SQL Server

SQL Server性能 电子书:高性能SQL Server SO问题:最好的SQL Server性能优化技术是什么? 布伦特欧扎尔的性能调优页 SqlServerPedia的性能调优页面 书:Sql Server 2008内部 如何识别运行缓慢的查询与SQL分析器

Sybase SQL Anywhere

博客:SQL Anywhere 书:SQL Anywhere Studio 9开发人员指南

JDBC

JDBC性能技巧


当前回答

对于甲骨文,Jonathan Lewis的《基于成本的甲骨文:基础》。

其他回答

我还要补充一点,除了理论上对数据库进行调优外,还应该使用跟踪SQL调用的分析器对应用程序进行分析。

尽管您的初衷是好的,但还是会有一些不好的调用潜入您的应用程序,通常会导致90%的性能相关问题。

对于MySQL,性能调优的“圣经”是高性能MySQL

首先,我要了解数据库在基本层面上是如何工作的。数据如何存储在磁盘上,创建索引做什么,查询计划优化如何工作,计划如何缓存,缓存的计划何时过期。

如果您能记住所有这些内容,那么关于调优的大多数建议似乎都是显而易见的。

这是一本关于MSSQL的好书

SQL Server内部结构

PostgreSQL快速优化(查询优化)

简短的阅读,很好地解释了很多事情,并且“工作”是一个真实的例子,这对我们这些学习更好的人来说是很好的。

在看到PostgreSQL的wiki链接后,我想我应该用mysql/oracle文档的链接来编辑这篇文章,这并不是一个真正的优化指南,但这两个都是很好的资源,尤其是mysql的那个。用于优化和任何其他调优功能。

下面是另一本备受推崇的、与平台无关的书:

Dan Tow的SQL调优:生成最佳执行计划

包含Oracle、MS SQL和IBM DB2的一些具体示例,但所涉及的技术也应该适用于其他平台。