From a4ffb42e2d04b84c912bf697d7f534fbae24639f Mon Sep 17 00:00:00 2001 From: RG Date: Wed, 24 Jul 2024 22:28:47 +0100 Subject: [PATCH] =?UTF-8?q?=1B[200~Formatted=20and=20sorted=20new=20column?= =?UTF-8?q?s=20correctly.=20Added=20comment=20to=20explain=20why=20this=20?= =?UTF-8?q?is=20needed.?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- sp_QuickieStore/sp_QuickieStore.sql | 36 ++++++++++++++--------------- 1 file changed, 17 insertions(+), 19 deletions(-) diff --git a/sp_QuickieStore/sp_QuickieStore.sql b/sp_QuickieStore/sp_QuickieStore.sql index 4cf6187..f14efc2 100644 --- a/sp_QuickieStore/sp_QuickieStore.sql +++ b/sp_QuickieStore/sp_QuickieStore.sql @@ -6799,11 +6799,9 @@ FROM I find it's helpful. */ + CASE WHEN @sort_order = 'plan count by hashes' - THEN N' - , hashes.plan_hash_count_for_query_hash, hashes.query_hash' + THEN N' , hashes.plan_hash_count_for_query_hash, hashes.query_hash' WHEN @sort_order_is_a_wait = 1 - THEN N' - , waits.total_query_wait_time_ms AS total_wait_time_from_sort_order_ms' + THEN N' , waits.total_query_wait_time_ms AS total_wait_time_from_sort_order_ms' ELSE N'' END ) @@ -7043,14 +7041,13 @@ FROM because our SELECT is just x.*. But, really, is having the columns visible in the output a bad thing? - I find it's helpful. + I find it's helpful, but it does mean that we have to format them + when applicable. */ + CASE WHEN @sort_order = 'plan count by hashes' - THEN N' - , hashes.plan_hash_count_for_query_hash, hashes.query_hash' + THEN N' , FORMAT(hashes.plan_hash_count_for_query_hash, ''N0'') AS plan_hash_count_for_query_hash, hashes.query_hash' WHEN @sort_order_is_a_wait = 1 - THEN N' - , waits.total_query_wait_time_ms AS total_wait_time_from_sort_order_ms' + THEN N' , FORMAT(waits.total_query_wait_time_ms, ''N0'') AS total_wait_time_from_sort_order_ms' ELSE N'' END ) @@ -7267,11 +7264,9 @@ FROM I find it's helpful. */ + CASE WHEN @sort_order = 'plan count by hashes' - THEN N' - , hashes.plan_hash_count_for_query_hash, hashes.query_hash' + THEN N' , hashes.plan_hash_count_for_query_hash, hashes.query_hash' WHEN @sort_order_is_a_wait = 1 - THEN N' - , waits.total_query_wait_time_ms AS total_wait_time_from_sort_order_ms' + THEN N' , waits.total_query_wait_time_ms AS total_wait_time_from_sort_order_ms' ELSE N'' END ) @@ -7486,14 +7481,13 @@ FROM because our SELECT is just x.*. But, really, is having the columns visible in the output a bad thing? - I find it's helpful. + I find it's helpful, but it does mean that we have to format them + when applicable. */ + CASE WHEN @sort_order = 'plan count by hashes' - THEN N' - , hashes.plan_hash_count_for_query_hash, hashes.query_hash' + THEN N' , FORMAT(hashes.plan_hash_count_for_query_hash, ''N0'') AS plan_hash_count_for_query_hash, hashes.query_hash' WHEN @sort_order_is_a_wait = 1 - THEN N' - , waits.total_query_wait_time_ms AS total_wait_time_from_sort_order_ms' + THEN N' , FORMAT(waits.total_query_wait_time_ms, ''N0'') AS total_wait_time_from_sort_order_ms' ELSE N'' END ) @@ -7712,6 +7706,10 @@ ORDER BY ' + WHEN 'plan count by hashes' THEN N'x.plan_hash_count_for_query_hash DESC, x.query_hash' ELSE CASE WHEN @sort_order_is_a_wait = 1 THEN N'x.total_wait_time_from_sort_order_ms' ELSE N'x.avg_cpu_time' END END + /* + The ORDER BY is on the same level as the topmost SELECT, which is just SELECT x.*. + This means that to sort formatted output, we have to un-format it. + */ WHEN 1 THEN CASE @sort_order @@ -7724,7 +7722,7 @@ ORDER BY ' + WHEN 'tempdb' THEN CASE WHEN @new = 1 THEN N'TRY_PARSE(x.avg_tempdb_space_used_mb AS money)' ELSE N'TRY_PARSE(x.avg_cpu_time AS money)' END WHEN 'executions' THEN N'TRY_PARSE(x.count_executions AS money)' WHEN 'recent' THEN N'x.last_execution_time' - WHEN 'plan count by hashes' THEN N'x.plan_hash_count_for_query_hash DESC, x.query_hash' + WHEN 'plan count by hashes' THEN N'TRY_PARSE(x.plan_hash_count_for_query_hash AS money) DESC, x.query_hash' ELSE CASE WHEN @sort_order_is_a_wait = 1 THEN N'TRY_PARSE(x.total_wait_time_from_sort_order_ms AS money)' ELSE N'TRY_PARSE(x.avg_cpu_time AS money)' END END END