我研究了30种不同的方法来从联接表中获取最新日期。需要专业人士的帮助。
注意:
-使用SolarWinds创建自定义SQL报告
-SQL的新手
我正在尝试获取我所有用户的列表,包括他们的用户名,主要组,名称和最新登录日期。该数据分布在两个表之间。
问题是我拥有的当前代码给了我一长串具有相同日期的重复用户。我只需要列出我所有用户的最新登录日期。
这是我想出的代码,它可以毫无问题地创建报告,但仍显示重复项,根本没有分组。我会缺少什么?
SELECT
b.AccountName,
a.UserName,
b.PrimaryGroup,
b.MemberList,
a.LogonDateTime,
a.UserID
FROM UDT_UserLastActivity a
JOIN (
SELECT UserID, MAX(LogonDateTime) maxLogon
FROM UDT_UserLastActivity
GROUP BY UserID
) maxRecord
ON maxRecord.UserID = a.UserID
AND maxRecord.maxLogon = a.LogonDateTime
JOIN UDT_User b
ON b.UserID = a.UserID
ORDER BY a.LogonDateTime DESC
在此先感谢任何愿意提供帮助的人!
答案 0 :(得分:2)
仅按分组并搜索最大值
SELECT
b.AccountName,
a.UserName,
b.PrimaryGroup,
b.MemberList,
max(a.LogonDateTime) as LastDate,
a.UserID
FROM UDT_UserLastActivity a
JOIN (
SELECT UserID, MAX(LogonDateTime) maxLogon
FROM UDT_UserLastActivity
GROUP BY UserID
) maxRecord
ON maxRecord.UserID = a.UserID
AND maxRecord.maxLogon = a.LogonDateTime
JOIN UDT_User b
ON b.UserID = a.UserID
group by
b.AccountName,
a.UserName,
b.PrimaryGroup,
b.MemberList,
a.UserID
ORDER BY a.LogonDateTime DESC
答案 1 :(得分:0)
我只需要列出所有用户的最新登录日期。
假设基本数据在users表中,并且您只需要活动表中的LogonDateTime:
SELECT
u.AccountName,
u.UserName,
u.PrimaryGroup,
u.MemberList,
(-- Scalar subquery to get the last logon
SELECT MAX(LogonDateTime)
FROM UDT_UserLastActivity AS ula
WHERE ula.UserID = u.UserID
) AS LastLogon,
u.UserID
FROM UDT_User AS u
ORDER BY LastLogon DESC
答案 2 :(得分:0)
您可以使用如上所述的分组方法,也可以只使用DISTINCT函数,如下所示:
SELECT DISTINCT
b.AccountName,
a.UserName,
b.PrimaryGroup,
b.MemberList,
a.LogonDateTime,
a.UserID
FROM UDT_UserLastActivity a
JOIN (
SELECT UserID, MAX(LogonDateTime) maxLogon
FROM UDT_UserLastActivity
GROUP BY UserID
) maxRecord
ON maxRecord.UserID = a.UserID
AND maxRecord.maxLogon = a.LogonDateTime
JOIN UDT_User b
ON b.UserID = a.UserID
ORDER BY a.LogonDateTime DESC;
此外,如果要使用MAX()函数,则应该可以完全删除maxrecord的子查询联接,请参见下文:
SELECT
b.AccountName,
a.UserName,
b.PrimaryGroup,
b.MemberList,
MAX(a.LogonDateTime) as maxLogonDateTime,
a.UserID
FROM UDT_UserLastActivity a
JOIN UDT_User b
ON b.UserID = a.UserID
GROUP BY b.AccountName,
a.UserName,
b.PrimaryGroup,
b.MemberList,
a.UserID
ORDER BY MAX(a.LogonDateTime) DESC;
希望有帮助。