I revised several of the queries this month in all five versions of the script. Once again, the main enhancements are additional comments and documentation about the queries, including more information about how to interpret the results.
Rather than having a separate blog post for each version, I have just put the links for all five major versions in this single post. There are two separate links for each version. The first one on the top left is the actual query script, and the one below on the right is the matching blank results spreadsheet.
SQL Server 2005 Diagnostic Information Queries
SQL Server 2005 Blank Results
SQL Server 2008 Diagnostic Information Queries
SQL Server 2008 Blank Results
SQL Server 2008 R2 Diagnostic Information Queries
SQL Server 2008 R2 Blank Results
SQL Server 2012 Diagnostic Information Queries
SQL Server 2012 Blank Results
SQL Server 2014 Diagnostic Information Queries
SQL Server 2014 Blank Results
The basic idea is that you should run each query in the set, one at a time (after reading the directions for that query). It is not really a good idea to simply run the entire batch in one shot, especially the first time you run these queries on a particular server, since some of these queries can take some time to run, depending on your workload and hardware. I also think it is very helpful to run each query, look at the results and think about the emerging picture of what is happening on your server as you go through the complete set.
You need to click on the top left square of the results grid in SSMS to select all of the results, and then right-click and select “Copy with Headers” to copy all of the results, including the column headers to the Windows clipboard. Then you paste the results into the matching tab in the blank results spreadsheet. There are also some comments on how to interpret the results after each query.
About half of the queries are instance specific and about half are database specific, so you will want to make sure you are connected to a database that you are concerned about instead of the master system database. Running the database-specific queries while being connected to the master database is a very common mistake that I see people making when they run these queries.
Note: These queries are stored on Dropbox. I occasionally get reports that the links to the queries and blank results spreadsheets do not work, which is most likely because Dropbox is blocked wherever people are trying to connect.
I also occasionally get reports that some of the queries simply don’t work. This usually turns out to be an issue where people have some of their user databases in 80 compatibility mode, which breaks many DMV queries.
It is also very important that you are running the correct version of the script that matches the major version of SQL Server that you are running. There is an initial query in each script that tries to confirm that you are using the correct version of the script for your version of SQL Server. If you are not using the correct version of these queries for your version of SQL Server, some of the queries are not going to work correctly.
If you want to understand how to better run and interpret these queries, you should consider listening to my three latest Pluralsight courses, which are SQL Server 2014 DMV Diagnostic Queries – Part 1 , SQL Server 2014 DMV Diagnostic Queries – Part 2 and SQL Server 2014 DMV Diagnostic Queries – Part 3. All three of these courses are pretty short and to the point, at 67, 77, and 68 minutes respectively. Listening to these three courses is best way to thank me for maintaining and improving theses scripts…
Please let me know what you think of these queries, and whether you have any suggestions for improvements. Thanks!
4 thoughts on “SQL Server Diagnostic Information Queries for March 2015”
Just wanted to say thanks for providing these amazing tools to the community! I use them all the time analyzing customers SQL Servers.
Kind regards,
Björn
Glad that they are useful for you. Thanks!
Thanks for posting these. They go way beyond the ones that I have written.
You mentioned in your Atlanta MDF meeting that you had table creates for these if we wanted to store the information over time. Easy for me to create the tables using a Select Into, but even easier if you already have the table creates posted on here.
Thanks again
Actually, I don’t have CREATE TABLE statements for the results of these queries. What I said at the Atlanta MDF was that I knew that several different people around the world had written solutions in PowerShell or even C# to automatically run these queries and collect the results in an Excel spreadsheet or some other format. Mitch Wheat from Australia did something in C#, for example.
I don’t have any links to these, so your favorite search engine is your friend here.
Actually, here is one link:
http://sqlserverio.com/2013/04/12/parsing-glenn-berry-diq-queries-powershell/