首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Max (SQL-Server)

Max (SQL-Server)
EN

Stack Overflow用户
提问于 2010-05-17 06:12:16
回答 2查看 187关注 0票数 0

我有张桌子看起来像这样:

代码语言:javascript
复制
BARCODE      | PRICE  | STARTDATE
007023819815 | 159000 | 2008-11-17 00:00:00.000
007023819815 | 319000 | 2009-02-01 00:00:00.000

如何选择才能得到这样的结果:

代码语言:javascript
复制
BARCODE      | PRICE  | STARTDATE
007023819815 | 319000 | 2009-02-01 00:00:00.000

使用max日期进行选择。

提前谢谢。

EN

回答 2

Stack Overflow用户

发布于 2010-05-17 08:25:32

代码语言:javascript
复制
SELECT TOP 1 barcode, price, startdate
FROM TableName
ORDER BY startdate DESC

或者如果可以有多个行。

代码语言:javascript
复制
SELECT barcode, price, startdate
FROM TableName A
WHERE startdate = (SELECT max(startdate) FROM TableName B WHERE B.barcode = A.barcode)

UPDATE更改了第二个查询,以查看每个条形码的最大值。

票数 2
EN

Stack Overflow用户

发布于 2010-05-17 08:21:53

一种优雅的方法是使用解析函数row_number

代码语言:javascript
复制
SELECT  barcode, price, startdate
FROM    (
        SELECT  *
        ,  ROW_NUMBER() OVER (PARTITION BY barcode ORDER BY startdate DESC) as rn
        FROM    YourTable
        ) subquery
WHERE   rn = 1

如果性能是一个问题,请查看这篇博客文章中的一些更复杂的选项。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/2846976

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档