SQL-选择NVARCHAR列时的最新最大日期
我只想从数据库中选择最新的输入 目前,它总是给我所有的意见,即使我用最大过滤 查询的简化版本SQL-选择NVARCHAR列时的最新最大日期,sql,date,duplicates,max,Sql,Date,Duplicates,Max,我只想从数据库中选择最新的输入 目前,它总是给我所有的意见,即使我用最大过滤 查询的简化版本 SELECT A.[Id], UD.[Name], MAX(CONVERT(DATE, AN.[PostedOn])) 'date', CAST(AN.[Content] AS NVARCHAR(MAX)) 'comment' FROM [dbo].[Account] A LEFT JOIN [dbo].[UserData] UD ON A.[U
SELECT
A.[Id],
UD.[Name],
MAX(CONVERT(DATE, AN.[PostedOn])) 'date',
CAST(AN.[Content] AS NVARCHAR(MAX)) 'comment'
FROM
[dbo].[Account] A
LEFT JOIN
[dbo].[UserData] UD ON A.[UserId] = UD.UserId
LEFT JOIN
[dbo].[Note] AN ON UD.[UserId] = AN.[CustomerID]
GROUP BY
A.[Id], UD.[Name], CAST(AN.[Content] AS NVARCHAR(MAX))
当前结果
+---------+------------------------+------------+-------+
|id |Name |Date |Comment|
+---------+------------------------+------------+-------+
|01 |John |2017-08-15 |Blue |
|01 |John |2017-07-10 |Green |
|02 |Bob |2017-07-15 |Green |
|02 |Bob |2017-06-05 |Red |
|03 |Eric |2017-08-15 |Yellow |
|04 |Karl |2017-08-15 |NULL |
|04 |Karl |2017-06-10 |Black |
+---------+------------------------+------------+-------+
预期/预期结果:
+---------+------------------------+------------+-------+
|id |Name |Date |Comment|
+---------+------------------------+------------+-------+
|01 |John |2017-08-15 |Blue |
|02 |Bob |2017-07-15 |Green |
|03 |Eric |2017-08-15 |Yellow |
|04 |Karl |2017-08-15 |NULL |
+---------+------------------------+------------+-------+
仅供参考,如果我将CASTAN.[Content]作为NVARCHARMAX“comment”从我的查询中删除,那么我将不再看到“重复”的名称/Id,但不会看到任何注释
有什么想法吗?使用行号:
这个。用于所需列的列表
请注意:您的查询没有按最大值进行过滤。您的查询正在使用聚合查询计算最大值。了解过滤和聚合之间的区别很重要。标记您正在使用的dbms,以及其中的一些产品细节。。。
SELECT
t.id, t.Name, t.date, t.Comment
FROM
(
SELECT A.id, UD.Name, CONVERT(date, AN.[PostedOn]) AS date, t.Comment,
ROW_NUMBER() OVER (PARTITION by t.id
ORDER BY CONVERT(date, AN.[PostedOn]) DESC) rn
FROM [dbo].[Account] A
LEFT JOIN [dbo].[UserData] UD
ON A.[UserId] = UD.UserId
LEFT JOIN [dbo].[Note] AN
ON UD.[UserId] = AN.[CustomerID]
) t
WHERE t.rn = 1
SELECT
t.id, t.Name, t.date, t.Comment
FROM
(
SELECT A.id, UD.Name, CONVERT(date, AN.[PostedOn]) AS date, t.Comment,
ROW_NUMBER() OVER (PARTITION by t.id
ORDER BY CONVERT(date, AN.[PostedOn]) DESC) rn
FROM [dbo].[Account] A
LEFT JOIN [dbo].[UserData] UD
ON A.[UserId] = UD.UserId
LEFT JOIN [dbo].[Note] AN
ON UD.[UserId] = AN.[CustomerID]
) t
WHERE t.rn = 1