By: Jeremy Kadlec | Comments | Related: > Upgrades and Migrations
Problem
My company has recently upgraded to SQL Server 2000 Service Pack 4 and we have experienced significant performance issues. Overall our performance baseline has dropped significantly (more than 50%) immediately after the service pack installation. We need to correct our performance issue, determine the problematic symptoms and the root cause in the service pack. How should we do so?
Solution
In researching this issue further take the following steps to address the item:
- Captured performance metrics to determine the worst performing queries
- Researched the individual queries to determine the root cause
- Determined that table scanning was occurring frequently in queries post SQL Server 2000 Service Pack 4
- Determined the cause of the table scanning as implicit conversions of mismatched data types
- Data types do not match between the embedded T-SQL in the front end code\stored procedures to the views and to the base tables
- In some examples the implicit conversion and data type mismatch problem was related to the following:
- NUMERIC to DECIMAL
- NUMERIC to INTEGER
- VARCHAR to INTEGER
- The implicit conversion performed a table scan as opposed to using an index as was the case with SQL Server 2000 Service Pack 3
- In some examples the implicit conversion and data type mismatch problem was related to the following:
To resolve the immediate issue, take the following steps:
- Identify the data types mismatches and correct them in logical groupings in order to properly test the application
- Correct the data type mismatches starting from the tables, then the views, next move on to the stored procedures and embedded T-SQL code in the front end to ensure the data types are consistent
- Review the query plans to ensure the expected indexes are being used following the code changes
- Perform both functional and load testing on the new versions of the code
- Perform some basic maintenance tasks
Next Steps
- Ensure that the data types are consistent and follow database design best practices (primary keys, referential integrity, data type selection, etc.) for your applications as this release with Service Pack 4 was considered a bug fix from Microsoft
- Conduct load testing to ensure the application will perform as expected following the upgrade
- This would be a proactive approach to identify potential issues prior to the production release
- Review the release notes and service pack related information from Microsoft
- Contact your vendors to ensure they have tested their application with the new release
- Build a rollback plan into the equation in case you have an issue
- Be aware of rollback issues with SQL Server 2005
About the author
This author pledges the content of this article is based on professional experience and not AI generated.
View all my tips