sqlschool.gr logo

articles

Articles of SQLschool.gr Team

DBCC OPTIMIZER_WHATIF Apocalypse (UPDATE)

Antonios Chatzipavlis
Saturday 09 February 2013

Πριν από μερικούς μήνες σας είχα αναφέρει την DBCC OPTIMIZER_WHATIF, ένα undocumented dbcc statement. Στο post εκείνο είχα προσπαθήσει να βρω πολλά πράγματα για την συγκεκριμένη αλλά όπως συμβαίνει πάντα όταν κάτι είναι undocumented δεν μπορείς να βρεις πολλά τουλάχιστον στην αρχή. Παρόλα αυτά έστω και έτσι, με τα λίγα, προσωπικά την χρησιμοποίησα και την χρησιμοποιώ για να ελέγξω τα queries μου με διαφορετικό αριθμό CPUs.

Κάποια στιγμή έπαιζα με τον Process Explorer και κοίταζα με αυτόν το service του SQL Server και κάτι μου κίνησε το ενδιαφέρον ήταν κάτι strings που μετά από πειραματισμό τα έβλεπα μόνο όταν είχα εκτελέσει το εν λόγο dbcc  statement.

Με δύο απλές κινήσεις και αφού χτυπούσα το κεφάλι μου σε μια γωνία γιατί δεν το είχα κάνει νωρίτερα (ου γαρ έρχεται μόνο) αποκαλύφθηκε μπροστά μου το statement. Με δύο trace flags (κυρίως με το δεύτερο) και με μερικούς πειραματισμούς στις παραμέτρους είχα τα πάντα για αυτό
Με το παρακάτω επιβεβαίωσα την σύνταξη του dbcc statement ενώ με το επόμενο είχα όλες τις δυνατές τιμές στις παραμέτρους και ιδιαίτερα για την πρώτη που στη ουσία είναι και η βασική.

DBCC TRACEON (2588) WITH NO_INFOMSGS;
DBCC HELP ('OPTIMIZER_WHATIF') WITH NO_INFOMSGS;
GO

/* output
dbcc OPTIMIZER_WHATIF ({property/cost_number | property_name} [, {integer_value | string_value} ])
*/

DBCC TRACEON(3604) WITH NO_INFOMSGS
DBCC OPTIMIZER_WHATIF(0) WITH NO_INFOMSGS;
GO

/* output
---------------------------------------------------------

Optimizer what-if status

---------------------------------------------------------

property_number current_value default_value property_name

---------------------------------------------------------

         1                  0             0 CPUs

         2                  0             0 MemoryMBs

         3                  0             0 Bits

         4               1000          1000 ParallelCardThreshold

         5                  1             1 ParallelCostThreshold

         6                200           200 ParallelCardCrossProd

         7                 50            50 LowCEThresholdFactorBy10

         8                 12            12 HighCEThresholdFactorBy10

         9             100000        100000 CEThresholdFactorCrossover

        10                 10            10 DMLChangeThreshold
*/

Έτσι πλέον ξέρουμε όλες τις δυνατές τιμές στην πρώτη και βασική παράμετρο που είτε μπορούμε να την ορίσουμε με τον property number είτε με το property name για παράδειγμα

DBCC OPTIMIZER_WHATIF(CPUs,16) WITH NO_INFOMSGS;
GO

DBCC OPTIMIZER_WHATIF(Status) WITH NO_INFOMSGS;
GO

DBCC OPTIMIZER_WHATIF(ResetAll) WITH NO_INFOMSGS;
GO

Παρόλα αυτά όμως από τον Process Explorer είχα ακόμα δύο strings που δεν εμφανίζονται στο παραπάνω output και αυτά είναι τα Status και ResetAll. Με το Status μπορείς να δεις το τι έχεις ορίσει σε κάθε property και στην ουσία είναι το property value μηδέν ενώ με την ResetAll κάνεις reset όλες τις τιμές (current_value) στις default τιμές. Στο σημείο θα πρέπει να αναφερθεί ότι σε SQL Server 2005 αυτές δεν παίζουν.

Επίσης τα 7, 8, 9, 10 υπάρχουν μόνο στο SQL Server 2012.

Από μια πρώτη ματιά από το 4 και μετά τα properties πρέπει κυρίως να αφορούν την Parallel Data Warehouse, αλλά αυτό θέλει περισσότερη έρευνα που μόλις ολοκληρώσω θα σας ενημερώσω.

Το σημαντικό όμως πλέον είναι ότι μπορούμε να δοκιμάσουμε τα queries μας με συνδυασμούς σε CPUs και Memory και να γνωρίζουμε εκ των προτέρων πως αυτά θα συμπεριφερθούν.

/*antonch*/

Antonios Chatzipavlis

Antonios Chatzipavlis

Antonios is a Data Solutions Consultant and Trainer. He has been working in IT since 1988. In his career, he has worked as senior developer, IT Manager, Solutions Architect and IT Consultant. Since 1995 he has been devoted on new technologies and software development tools, mainly by Microsoft, either by training company staff and colleagues or assisting them in design, development and implementation as a consultant or chief developer. He has focused in Databases and Data Science since 1995. He specialized in Microsoft SQL Server since version 6.0 in areas like SQL Server Internals, Database Design and Development, Business Intelligence and in 2010 he has started working with Azure Data Platform, NoSQL databases, Big Data Technologies and Machine Learning. He is an active member of many IT communities in Greece, answering colleagues' questions and writing articles in his web site. He is the owner of SQLschool.gr which is a community portal with a lot of information about Microsoft SQL Server. He has been a Microsoft Certified Trainer (MCT) since 2000. Microsoft honored him as MVP on Data Platform due to his activities in SQL Server since 2010. He holds a large number of Microsoft Certifications and Microsoft SQL Server Certifications since version 6.5.

Tip

What's New in SQL Server 2022 - Episodes

More Tips...

Become a member

If you want to receive updates from us become a member to our community.

Connect

Explore

Learn


sqlschool.gr © 2010-2024 All rights reserved

This site uses cookies for operational and analytics purposes only. By continuing to browse this site, you agree to their use.