如何解决按几列进行分组,包括MAX以限制行,但不按分组显示列
我每5分钟将sp_whoisactive输出到一个日志表,并希望聚合诸如经过时间或cpu之类的列。我获得唯一记录的最佳机会是session_id,login_time,login_name,我希望每个唯一记录的MAX(collection_time)。
我的问题是如何在一个查询中做到这一点?
我尝试了各种变体,但始终无法获得所需的输出。我结束了2个步骤:1)将组分组到## Temp表中,然后2)然后将## temp连接到日志表中,以获取报告中所需的所有列。
第1步查询:
enter code hereIF(OBJECT_ID('tempdb..##TEMP') IS NOT NULL) BEGIN DROP TABLE ##TEMP END
SELECT *
INTO ##TEMP
FROM (
select distinct Session_id,login_name,login_time,max(collection_time) as MaxCollection
from [MyDB].[DBA].[WhoIsActive]
group by login_name,session_id,login_time
) AS X
第2步查询:
DECLARE @yesterday DATETIME,@today DATETIME
SET @yesterday = DATEADD(hh,12,DATEADD(dd,DATEDIFF(dd,GETDATE()-1),0))
SET @today = DATEADD(hh,11,GETDATE()-0),0))
SELECT
tt.[session_id],tt.[tasks],tt.[login_time],tt.[login_name],tt.[start_time],tt.[collection_time],tt.[dd hh:mm:ss.mss] as ElapsedTime,(Substring(tt.[dd hh:mm:ss.mss],1,2) * 86400) + (Substring(tt.[dd hh:mm:ss.mss],4,2) * 3600) + (Substring(tt.[dd hh:mm:ss.mss],7,2) * 60) + (Substring(tt.[dd hh:mm:ss.mss],10,2)) as totalseconds,tt.[host_name],tt.[status],tt.[CPU],tt.[program_name]
FROM [MyDB].[DBA].[WhoIsActive] tt
right JOIN ##TEMP kk
on tt.session_id = kk.session_id and tt.collection_time = kk.MaxCollection
--where kk.start_time between @yesterday and @today --and kk.login_name like '%ETL%'
order by tt.login_name asc,tt.session_id asc,login_time desc
解决方法
我获得唯一记录的最佳机会是
[]chan int
,session_id
,login_time
,我希望每个唯一记录都login_name
。
如果只希望每个元组的最大收集时间,则使用聚合:
MAX(collection_time)
另一方面,如果要 entire 对应的行,则一个选项是select session_id,login_time,login_name,max(collection_time) max_collection_time
from whoisactive
group by session_id,login_name
:
row_number()
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。