select * from (
SELECT s2.dbid,
s1.sql_handle,
(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,
execution_count,
plan_generation_num,
last_execution_time,
total_worker_time/1000/1000 as total_worker_time,
last_worker_time,
min_worker_time/1000/1000 as min_worker_time,
max_worker_time/1000/1000 as max_worker_time,
total_physical_reads,
last_physical_reads,
min_physical_reads,
max_physical_reads,
total_logical_writes,
last_logical_writes,
min_logical_writes,
max_logical_writes
FROM sys.dm_exec_query_stats AS s1
CROSS APPLY sys.dm_exec_sql_text(sql_handle) AS s2
WHERE s2.objectid is null --and (total_worker_time/1000/1000)>10
) t
where t.last_execution_time>='2015-09-16 14:51'
--order by last_execution_time desc
and total_worker_time>10
ORDER BY min_worker_time desc
--ORDER BY s1.last_execution_time desc
SELECT s2.dbid,
s1.sql_handle,
(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,
execution_count,
plan_generation_num,
last_execution_time,
total_worker_time/1000/1000 as total_worker_time,
last_worker_time,
min_worker_time/1000/1000 as min_worker_time,
max_worker_time/1000/1000 as max_worker_time,
total_physical_reads,
last_physical_reads,
min_physical_reads,
max_physical_reads,
total_logical_writes,
last_logical_writes,
min_logical_writes,
max_logical_writes
FROM sys.dm_exec_query_stats AS s1
CROSS APPLY sys.dm_exec_sql_text(sql_handle) AS s2
WHERE s2.objectid is null --and (total_worker_time/1000/1000)>10
) t
where t.last_execution_time>='2015-09-16 14:51'
--order by last_execution_time desc
and total_worker_time>10
ORDER BY min_worker_time desc
--ORDER BY s1.last_execution_time desc