views:

34

answers:

3

Is there a way to get the SQL text for the last few queries?

I am using Microsoft SQL Server 2005

+1  A: 

The only way I'm aware of is to have the SQL Server Profiler running. Unfortunately this needs to be started prior to the queries being executed, so if you're hoping to catch something that's happened on an "ad hoc" basis, it won't be suitable. If you're trying to track what a piece of code's doing and want to capture the queries it executes, it should work a treat.

Rob
@Rob: Thank you. I will look into it.
Shiftbit
+4  A: 

If using SQL 2005:

SELECT deqs.last_execution_time AS [Time], dest.TEXT AS [Query]
FROM sys.dm_exec_query_stats AS deqs
CROSS APPLY sys.dm_exec_sql_text(deqs.sql_handle) AS dest
ORDER BY deqs.last_execution_time DESC

Great tip from SQLAuthority!

Dustin Laine
I confirm that it also works with Sql Server 2008.
Pierre-Alain Vigeant
+2  A: 

Yes, take a look, this will give you the 50 most recent executed SQL statements

sql 2005 and up only

SELECT TOP 50 * FROM(SELECT COALESCE(OBJECT_NAME(s2.objectid),'Ad-Hoc') AS ProcName,
  execution_count,s2.objectid,
    (SELECT TOP 1 SUBSTRING(s2.TEXT,statement_start_offset / 2+1 ,
      ( (CASE WHEN statement_end_offset = -1
  THEN (LEN(CONVERT(NVARCHAR(MAX),s2.TEXT)) * 2)
ELSE statement_end_offset END)- statement_start_offset) / 2+1)) AS sql_statement,
       last_execution_time
FROM sys.dm_exec_query_stats AS s1
CROSS APPLY sys.dm_exec_sql_text(sql_handle) AS s2 ) x
WHERE sql_statement NOT like 'SELECT TOP 50 * FROM(SELECT %'
--and OBJECTPROPERTYEX(x.objectid,'IsProcedure') = 1
ORDER BY last_execution_time DESC
SQLMenace
37000(321)[Microsoft][ODBC SQL Server Driver][SQL Server]"sql_handle" is not a recognized table hints option. If it is intended as a parameter to a table-valued function, ensure that your database compatibility mode is set to 90.
Shiftbit
Like I said 2005 and up only, for 2000 run profiler. Next time indicate which version of sql server you are running
SQLMenace
Microsoft SQL Server 2005 - 9.00
Shiftbit
Not according to the error. Run this and see if it returns 90 or not.....select compatibility_level from sys.databases where database_id = DB_ID()
SQLMenace
@SQLMenance: Compatibility_Level = 80. Weird because Select @@Version Returns 2005. Thank you for helping me troubleshoot.
Shiftbit