SQL Server 2008 Query Performance Tuning Distilled.pdf

(10131 KB) Pobierz
373140960 UNPDF
373140960.035.png
SQL Server 2008 Query
Performance Tuning
Distilled
Grant Fritchey and Sajal Dam
373140960.036.png 373140960.037.png 373140960.038.png 373140960.001.png 373140960.002.png 373140960.003.png 373140960.004.png 373140960.005.png 373140960.006.png 373140960.007.png
SQL Server 2008 Query Performance Tuning Distilled
Copyright © 2009 by Grant Fritchey and Sajal Dam
All rights reserved. No part of this work may be reproduced or transmitted in any form or by any means,
electronic or mechanical, including photocopying, recording, or by any information storage or retrieval
system, without the prior written permission of the copyright owner and the publisher.
ISBN-13 (pbk): 978-1-4302-1902-6
ISBN-13 (electronic): 978-1-4302-1903-3
Printed and bound in the United States of America 9 8 7 6 5 4 3 2 1
Trademarked names may appear in this book. Rather than use a trademark symbol with every occurrence
of a trademarked name, we use the names only in an editorial fashion and to the benefit of the trademark
owner, with no intention of infringement of the trademark.
Lead Editor: Jonathan Gennick
Development Editor: Douglas Pundick
Technical Reviewer: Joseph Sack
Editorial Board: Clay Andres, Steve Anglin, Mark Beckner, Ewan Buckingham, Tony Campbell,
Gary Cornell, Jonathan Gennick, Michelle Lowman, Matthew Moodie, Jeffrey Pepper, Frank Pohlmann,
Ben Renow-Clarke, Dominic Shakeshaft, Matt Wade, Tom Welsh
Project Manager: Richard Dal Porto
Copy Editor: Kim Wimpsett
Associate Production Director: Kari Brooks-Copony
Production Editor: Kelly Winquist
Compositor: Patrick Cunningham
Proofreader: April Eddy
Indexer: John Collin
Artist: April Milne
Cover Designer: Kurt Krames
Manufacturing Director: Tom Debolski
Distributed to the book trade worldwide by Springer-Verlag New York, Inc., 233 Spring Street, 6th Floor,
New York, NY 10013. Phone 1-800-SPRINGER, fax 201-348-4505, e-mail kn`ano)ju<olnejcan)o^i*_ki , or
visit dppl6++sss*olnejcankjheja*_ki .
For information on translations, please contact Apress directly at 2855 Telegraph Avenue, Suite 600,
Berkeley, CA 94705. Phone 510-549-5930, fax 510-549-5939, e-mail ejbk<]lnaoo*_ki , or visit dppl6++sss*
]lnaoo*_ki .
Apress and friends of ED books may be purchased in bulk for academic, corporate, or promotional use.
eBook versions and licenses are also available for most titles. For more information, reference our Special
Bulk Sales–eBook Licensing web page at dppl6++sss*]lnaoo*_ki+ejbk+^qhgo]hao .
The information in this book is distributed on an “as is” basis, without warranty. Although every precau-
tion has been taken in the preparation of this work, neither the author(s) nor Apress shall have any liability
to any person or entity with respect to any loss or damage caused or alleged to be caused directly or indi-
rectly by the information contained in this work.
The source code for this book is available to readers at dppl6++sss*]lnaoo*_ki .
373140960.008.png 373140960.009.png 373140960.010.png 373140960.011.png 373140960.012.png 373140960.013.png 373140960.014.png 373140960.015.png 373140960.016.png
Contents at a Glance
About the Author .................................................................xix
About the Technical Reviewer . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . xxi
Acknowledgments ...............................................................xxiii
Introduction .................................................................... xxv
CHAPTER 1 SQL Query Performance Tuning ..................................1
CHAPTER 2 System Performance Analysis ..................................17
CHAPTER 3 SQL Query Performance Analysis ...............................61
CHAPTER 4 Index Analysis ................................................101
CHAPTER 5 Database Engine Tuning Advisor ...............................151
CHAPTER 6 Bookmark Lookup Analysis ....................................163
CHAPTER 7 Statistics Analysis .............................................175
CHAPTER 8 Fragmentation Analysis .......................................209
CHAPTER 9 Execution Plan Cache Analysis .................................241
CHAPTER 10 Stored Procedure Recompilation ...............................283
CHAPTER 11 Query Design Analysis .........................................313
CHAPTER 12 Blocking Analysis .............................................351
CHAPTER 13 Deadlock Analysis .............................................401
CHAPTER 14 Cursor Cost Analysis ..........................................415
CHAPTER 15 Database Workload Optimization ...............................439
CHAPTER 16 SQL Server Optimization Checklist .............................475
INDEX .......................................................................497
iii
373140960.017.png 373140960.018.png 373140960.019.png 373140960.020.png 373140960.021.png 373140960.022.png 373140960.023.png 373140960.024.png 373140960.025.png
Contents
About the Author .................................................................xix
About the Technical Reviewer . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . xxi
Acknowledgments ...............................................................xxiii
Introduction .................................................................... xxv
CHAPTER 1 SQL Query Performance Tuning .............................1
The Performance-Tuning Process ..................................2
The Core Process ............................................2
Iterating the Process .........................................4
Performance vs. Price .............................................7
Performance Targets .........................................7
“Good Enough” Tuning .......................................7
Performance Baseline .............................................8
Where to Focus Efforts ............................................9
SQL Server Performance Killers ...................................10
Poor Indexing ..............................................11
Inaccurate Statistics ........................................11
Excessive Blocking and Deadlocks ............................11
Non-Set-Based Operations ...................................12
Poor Query Design ..........................................12
Poor Database Design .......................................12
Excessive Fragmentation ....................................13
Nonreusable Execution Plans .................................13
Poor Execution Plans ........................................13
Frequent Recompilation of Execution Plans ....................14
Improper Use of Cursors .....................................14
Improper Configuration of the Database Log ...................14
Excessive Use or Improper Configuration of tempdb .............14
Summary .......................................................15
v
373140960.026.png 373140960.027.png 373140960.028.png 373140960.029.png 373140960.030.png 373140960.031.png 373140960.032.png 373140960.033.png 373140960.034.png
Zgłoś jeśli naruszono regulamin