I've seen a couple of blog posts where fairly knowledgeable sounding MVPs are still using sys.sysprocesses rather than the recommended DMVs: sys.dm_exec_connections, sys.dm_exec_sessions and sys.dm_exec_requests.
Given that sysprocesses is deprecated, I'm curious why anyone would continue to use it, particularly MVPs. Is it just that using sysprocesses is less hassle than joining three DMVs or is there a better reason for using it?
The two blog posts I mentioned were:
Adam Machanic: Smashing a DMV Myth
Tim Chapman: Find blocking processes using recursion in SQL Server 2005
Best Answer
sys.sysprocesses still contains information that is either very cumbersome or impossible to get from the DMVs, since they weren't complete (they are a bit better with each new release, but not 100% yet). Two standout examples:
I suspect this backward compatibility view will remain around until a few versions after they supply the information directly through the DMVs.