如何使用 SQL 查询从交易表中检索每年的所有最后交易

发布于 2025-01-09 11:11:45 字数 281 浏览 0 评论 0原文

我有一个表,记录所有交易以及交易日期和其他详细信息。我需要一个sql语句来检索每年的所有最后交易,特别是每年的最后交易日期。我正在使用 MSSQL 2014 例如,如果我的记录从 01/01/2000 开始,我需要获取从 01/01/2000 到现在的所有交易的最后日期。

预期结果示例:

TransactionDate
--------------------
12/31/2000
12/29/2001
12/30/2002
12/31/2003
.
.
.
12/30/2021

I have a table where I record all transactions with transaction date and other details . I need an sql statement to retrieve all the last transactions for every year, specially the last date of transaction for every year. I'm using MSSQL 2014
Ex, If my records starts from 01/01/2000, I need to get all the last date of transaction from 01/01/2000 to present.

Example expected result:

TransactionDate
--------------------
12/31/2000
12/29/2001
12/30/2002
12/31/2003
.
.
.
12/30/2021

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

你曾走过我的故事 2025-01-16 11:11:45

尝试使用 DATEPART 将 TransactionDate 分解为一年。一旦你有了这个,你可以选择 max TransactionDate 并按年份分组,以获得每年的最后一笔交易,

看起来像这样......

SELECT LastTransactionDateOfYear
FROM (
    SELECT DATEPART(year,TransactionDate),
        MAX(TransactionDate) LastTransactionDateOfYear
    FROM <yourtable>
    GROUP BY DATEPART(year,TransactionDate)
)

Try breaking your TransactionDate into a year using DATEPART. Once you have that, you can select max TransactionDate and group by year, to get the last transaction of each year

That would look like this…

SELECT LastTransactionDateOfYear
FROM (
    SELECT DATEPART(year,TransactionDate),
        MAX(TransactionDate) LastTransactionDateOfYear
    FROM <yourtable>
    GROUP BY DATEPART(year,TransactionDate)
)
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文