Troubleshooting Your First Low-performing T-SQL Query
https://app.pluralsight.com/library/courses/troubleshooting-first-low-performing-t-sql-query/table-of-contents
by Jared Westover
Module 1: Course Overview
- Course Overview
Module 2: Asking Questions about a Query
- Introduction
- What Is Low-performing?
- Developer Expectations
- - This course uses the WiredBrainCoffee database
- shows how to enable line numbers in SSMS
- shows how to refresh IntelliSense local cache - Demo: Setup Your Environment
- Start With Questions
- Demo: Ask Questions
- Breakdown Complex Queries
- Demo: Common Table Expressions
- - shows how to convert a derived query into a CTE
- performance is about the same but CTE are more readable - Demo: Nested CASE Expressions
- Summary
Module 3: Sources of Query Performance Issues
- Introduction
- Clicking Execute
- overview of the execute phase: Parser -> Algebraizer -> Optimizer -> Execution.
- SQL Server Storage
- discusses how sql server caches results in pages
- Return Fewer Pages
- use where clause and indexes to return fewer pages
- Demo: Page Count
- query to determine how many pages a table uses (sys.dm_db_partition_stats)
- Demo: Returning Fewer Pages
- - DBCC DROPCLEANBUFFERS will clear page cache
- removing ORDER BY from select query could speed up query. if you need the order by, consider an index - Indexes Drive Performance
- Invalidate Index Seeks
- careful not to invalidate seeks, forcing a full scan of an index
- Demo: Invalidate Index Seeks
- examples where seek is invalidated
WHERE CONVERT(CHAR(10), sDate,121) = '2019-03-03 ' ;
WHERE LOWER(eEmail) = 'Sally.Friend@gmail.com';
WHERE LTRIM(RTRIM((sp.Email))) = 'Sally.Friend@gmail.com';
WHERE id LIKE '%500' - Do You Need All the Columns?
- Demo: Problem With Select *
- Summary
Module 4: Performance Insights with SQL Server Tools
- Introduction
- Query Tuning Diminishing Returns
- Calculate Page Reads
- Use STATISTICS IO to get insight into a query; how many logical vs physical reads
- Demo: STATISTICS IO
- shows a query that can be used to determine how many pages a table has (using sys.dm_db_partition_stats, sys.tables, and sys.indexes)
- You can turn on STATISTIC IO ON just for a single query
- Result of STATISTICS IO is found in messages tab
- Understanding logical and physical reads
- Exploring an Execution Plan
- definition of Execution Plan: "A tool used for displaying the data retrieval methods chosen by the SQL Server Query Optimizer."
- Important Plan Operators
- difference between seek and scan
- you may want to remove ORDER BY clause as it may add overhead
- key lookups happen when a column in a SELECT statement is not part of an index
- a table without a clustered index is called a heap
- Demo: Reading an Execution Plan
- how to show execution plan in SSMS
- you can generate an execution plan without running the query (estimated plan)
- Demo: Important Plan Operators
- Dynamic Management Objects
- definition: "Dynamic management views and functions return server state information that can be used to monitor the health of a server instance, diagnose problems, and tune performance."
- can be used to determine how many times sql server used an index, how many times a PROC has been executed and its execution time, view all your execution plans in cache, fetch all indexed sql server thinks it is missing, find queries reading lots of pages, etc
- Demo: Missing Indexes & Top Queries
- data for Dynamic management views and functions is lost when sql server is restarted
- shows query for fetching missing indexes
- shows query for fetching queries with high logical reads
- Summary
Module 5: Query Tuning in the Real World
- Introduction
- Demo: Covering Index
- use EXECUTE sp_helpindex to view index on a table
- Covering indexes are indexes which "cover" all columns needed from a specific table, removing the need to access the physical table at all for a given query/ operation.
- with a covering index, there is an opportunity to drop a duplicate index
- example of using INCLUDE
- Demo: Filtered Index
- using a where clause created a filtered index
- use case for filtered index: when you don't want to return soft deleted rows
- Demo: Index Column Order
- shows a query for generating random numbers
- index column order matters; put the most unique column first
- Demo: Using Compression
- show a query for getting row count and size of an index
- can index can be compressed like this 'WITH (DATA COMPRESSION PAGE)'
- Demo: Rethinking Cursors
- shows query that can make cursors faster (CURSOR LOCAL STATIC READ ONLY FORWARD ONLY FOR)
- Cursors don't scale well over a larger dataset.
- using 'ON 1 = 0' with MERGE for doing inserts only
- using MERGE with OUTPUT and INTO
- shows an example of converting cursor with set based operation
- Demo: User-defined Function Improvements
- Microsoft made improvements to scalar user defined function in 2019
- scalar user defined functions can be used to encapsulate repeating code
- however, traditionality scalar user defined function have not been performant
- Take the Next Steps
Comments
Post a Comment