首页 > 解决方案 > 我需要用 php - mysql 列出产品的唯一最新版本

问题描述

我只是想列出产品的唯一最新版本。并非所有版本都具有相同的产品名称。

所以这: 在此处输入图像描述

而不是这个: 在此处输入图像描述

*表不是那么重要,我只想要代码来获取数据。
*表不是那么重要,我只想要代码来获取数据。

这是我的代码,但没有列出任何内容:

include("databaseinfo.php");
$sql = "SELECT product_name,release_date,version FROM product GROUP BY product_name ORDER BY product_ID DESC";
$result = mysqli_query($conn,$sql);
while ($b=mysqli_fetch_array($result,MYSQLI_ASSOC)){
    echo $b['product_name']." ".$b['release_date']." ".$b['version'];
}

我的产品表:

在此处输入图像描述

标签: phpmysqldatabasedatetimegreatest-n-per-group

解决方案


一种选择是使用子查询进行过滤:

select product_name, release_date, version
from product p
where release_date = (
    select max(p1.release_date)
    from product p1
    where p1.product_id = p.product_id
)

如果您正在运行 MySQL 8.0,您还可以使用rank()

select product_name, release_date, version
from (
    select p.*, rank() over(partition by product_id order by release_date desc)
    from product
) t
where rn = 1

这假设product_id唯一标识每个产品(因此您的表将有几行每个product_id) - 如果不是这种情况,请product_name改用。


推荐阅读