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