在GROUP BY查询之前获取最新条目 [英] Get the newest entry before a GROUP BY query

查看:97
本文介绍了在GROUP BY查询之前获取最新条目的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

使用postgres,我想检索每个不同的软件包,但检索每个组的最新软件包。

Using postgres, I would like to retrieve each different packages, but retrieve the most recent package for each group.

例如,我有一个名为product的表:

For example, I have this table named products:

package_name        price           date
-               |   52500.0 |   20080910
-               |   52900.0 |   20090422
-               |   52900.0 |   20090706
ELITE PACKAGE   |   62200.0 |   20080910
ELITE PACKAGE   |   62500.0 |   20090706
ELITE PACKAGE   |   62500.0 |   20090422
TECH PACKAGE    |   57200.0 |   20080910
TECH PACKAGE    |   58200.0 |   20090706
TECH PACKAGE    |   58200.0 |   20090422

我想通过SQL查询获得以下结果:

And I would like to get the following result with a SQL query:

-                   |   52900.0 |   20090706
ELITE PACKAGE       |   62500.0 |   20090706
TECH PACKAGE        |   58200.0 |   20090706

我已经尝试了几项(我认为)可以在mySQL中工作的方法,但是我

I have tried a couple of things that (I think) would have worked in mySQL, but I can't get it right for postgres.

有什么可能做的,我该怎么做?

Is it something possible to do, and how would I do it?

谢谢

斯蒂芬妮

推荐答案

SELECT t.package_name, p.price, t.MaxDate
    FROM (SELECT package_name, MAX(date) AS MaxDate
              FROM products
              GROUP BY package_name) t
        INNER JOIN products p
            ON t.package_name = p.package_name
                and t.MaxDate = p.date

这篇关于在GROUP BY查询之前获取最新条目的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆