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 Chatzipavlis is a highly experienced Data Solutions Consultant and Trainer. He has been working in the IT industry since 1988, holding various roles such as senior developer, IT Manager, Data & AI Solutions Architect and Consultant.

Since 1995, Antonios has focused on modern technologies and software development tools, primarily by Microsoft. He has specialized in Data & AI since 2000, with expertise in Microsoft Data Platform (SQL Server, Azure SQL Databases, Azure Synapse Analytics, Microsoft Fabric, Power BI, AI) and Databricks.

Antonios is also a Microsoft Certified Trainer (MCT) for over 25 years, has been recognized as a Microsoft Most Valuable Professional (MVP) in Data Platform since 2010 and he is in the Data Expert 40 Powerlist 2024 by Boussias. He is the co-founder and visionary behind XLYTiCA, a company dedicated to Data & AI solutions.

Episode

Task Flows in Microsoft Fabric

image

More Episodes...

Tip

Get Certified: Become a Fabric Data Engineer

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-2025 All rights reserved

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