I've always liked SP_WHO2. It is a simple command and has been around forever (well at least since 2000). Before SQL Server 2005 it was my go to command any time I thought I had blocking issues or needed quick information on a given SPID. I still use it, in spite of the additional DMVs that have largely superseded it because it is one quick command, it works on any version and I don't have to remember anything in the heat of battle.
But it is old and has some flaws. I've had some scripts over the year to address those flaws and I have tried a number of DMVs, but I just never felt like the extra work was worth it.
So, I recently found I needed to be able to see the actual command being currently executed by a given SPID. I found a number of solutions in my search, but when I found one by Pinal Dave, I realized that with some slight modification I could make it work for all SPIDS at once if I used sys.sysprocesses. I built that, and then realized that I finally had an SP_WHO2 replacement that was worth the hassle. This gives me everything I ever wanted out of SP_WHO2 with the added benefit of being sortable and it shows the actual SQL being executed by each SPID.
So, without further ado, my own humble addition to the SQL community:
SELECT s.spid
,s.blocked
,s.status
,s.cpu
,s.memusage
,s.physical_io
,s.program_name
,s.hostname
,s.loginame
,s.last_batch
,s.waittime
,s.lastwaittype
,t.text SQLText
FROM sys.sysprocesses S
CROSS APPLY sys.dm_exec_sql_text(sql_handle) T
WHERE s.spid >= 50
ORDER BY s.blocked desc, s.spid
Random thoughts and learnings from the world of SQL Server, B I, data and business.
Thursday, November 21, 2013
Wednesday, October 23, 2013
SSRS and the perils of inline comments
I just was working with a report that one of my customers was building and was forcefully reminded of something I already knew, but had forgotten.
The two types of comment notation in TSQL, namely "--" and "/* . . . */" are not entirely the same, and in certain places using the wrong one ( "--") can get you in big trouble.
Here is the scenario: My customer was working on creating a fairly simple report that had a somewhat complex query behind it. The query had originally been developed and debugged in SSMS, where it ran just fine.
He then pasted the tsql code into the query portion of the dataset in SSRS, using the "show as text" option. When run from there, it ran just fine. But when he tried to preview the report, it said that it couldn't process the dataset. So he contacted me.
I won't go into all the things I tried that didn't work, but here is the bottom line:
When he was developing this complex query he had put in a check and then commented it out using the "--" style comment. As long as the query was run in a formatted fashion, it ran fine, but when SSRS went to run the query, it didn't run it in a formatted fashion! Once SSRS saw that "--" it invalidated the rest of the statement (over half of the total code). As soon as I recognized this, I eliminated the comment and code and it ran without a problem.
Formatting of SQL code is not preserved in the running code. I had heard that this was a problem in other areas before, so I knew it in the back of my mind, and it was that which allowed me to recognize what was going on. I have heard other SQL authorities rail on the use of "--" in code before, advocating that you ALWAYS should us the "/* . . . */" style. I specifically remember it being mentioned as a problm in SSIS, but I had never run into this problem in SSRS before.
So, I resolve from this day forth to join the /* camp and only use it for my comments.
That is all.
The two types of comment notation in TSQL, namely "--" and "/* . . . */" are not entirely the same, and in certain places using the wrong one ( "--") can get you in big trouble.
Here is the scenario: My customer was working on creating a fairly simple report that had a somewhat complex query behind it. The query had originally been developed and debugged in SSMS, where it ran just fine.
He then pasted the tsql code into the query portion of the dataset in SSRS, using the "show as text" option. When run from there, it ran just fine. But when he tried to preview the report, it said that it couldn't process the dataset. So he contacted me.
I won't go into all the things I tried that didn't work, but here is the bottom line:
When he was developing this complex query he had put in a check and then commented it out using the "--" style comment. As long as the query was run in a formatted fashion, it ran fine, but when SSRS went to run the query, it didn't run it in a formatted fashion! Once SSRS saw that "--" it invalidated the rest of the statement (over half of the total code). As soon as I recognized this, I eliminated the comment and code and it ran without a problem.
So, the moral of the story is: Don't use the "--" style of code in any query you will run in SSRS!
Formatting of SQL code is not preserved in the running code. I had heard that this was a problem in other areas before, so I knew it in the back of my mind, and it was that which allowed me to recognize what was going on. I have heard other SQL authorities rail on the use of "--" in code before, advocating that you ALWAYS should us the "/* . . . */" style. I specifically remember it being mentioned as a problm in SSIS, but I had never run into this problem in SSRS before.
So, I resolve from this day forth to join the /* camp and only use it for my comments.
Always use "/* . . . */" for your comments. It never hurts, and will sometimes save you time and pain.
That is all.
Subscribe to:
Posts (Atom)