SELECT 查询从每组返回 1 行

2023-05-23数据库问题
2

本文介绍了SELECT 查询从每组返回 1 行的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

问题描述

限时送ChatGPT账号..

这是一个产品表,有几百万条记录.

This is a product table and have few million of records.

我想列出如下记录:
通常我使用:

I want to list record as below:
Normally I use:

SELECT id, 
       product_name, 
       store_id 
FROM product
GROUP BY store_id 
ORDER BY id.


目前有 SQL 性能问题.我需要 SQL 查询来输出这样的结果.


Currently having SQL performance issue. I need SQL query to output result like this.

推荐答案

有很多替代方案可以解决这个问题,我推荐的一个是加入一个单独获取最新 ID (假设对于每个 store_ID,该列都是 AUTO_INCREMENTed).

There are many alternatives to solves this, one which I recommend is to have joined a subquery which separately gets the latest ID (assuming that the column is AUTO_INCREMENTed) for each store_ID.

SELECT  a.*
FROM    tableName a
        INNER JOIN
        (
            SELECT  store_ID, MAX(ID) max_ID
            FROM    tableName
            GROUP BY store_ID
        ) b ON a.store_ID = b.store_ID AND
                a.ID = b.max_ID

  • SQLFiddle 演示
  • 为了获得更好的性能,请确保在这些列上有一个索引:IDstore_id.

    for better performance, be sure to have an index on these columns: ID and store_id.

    更新 1

    如果你想对每条记录设置限制,请在下面使用,

    if you want to have limit for every records, use this below,

    SELECT ID, product_Name, store_ID
    FROM   tableName a
    WHERE
      (
         SELECT COUNT(*) 
         FROM   tableName b
         WHERE  b.store_ID = a.store_ID AND b.ID >= a.ID
      ) <= 2;
    

    • SQLFiddle 演示
    • 这篇关于SELECT 查询从每组返回 1 行的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

      The End

相关推荐

Mysql目录里的ibtmp1文件过大造成磁盘占满的解决办法
ibtmp1是非压缩的innodb临时表的独立表空间,通过innodb_temp_data_file_path参数指定文件的路径,文件名和大小,默认配置为ibtmp1:12M:autoextend,也就是说在文件系统磁盘足够的情况下,这个文件大小是可以无限增长的。 为了避免ibtmp1文件无止境的暴涨导致...
2025-01-02 数据库问题
151

按天分组的 SQL 查询
SQL query to group by day(按天分组的 SQL 查询)...
2024-04-16 数据库问题
77

SQL 子句“GROUP BY 1"是什么意思?意思是?
What does SQL clause quot;GROUP BY 1quot; mean?(SQL 子句“GROUP BY 1是什么意思?意思是?)...
2024-04-16 数据库问题
62

MySQL groupwise MAX() 返回意外结果
MySQL groupwise MAX() returns unexpected results(MySQL groupwise MAX() 返回意外结果)...
2024-04-16 数据库问题
13

MySQL SELECT 按组最频繁
MySQL SELECT most frequent by group(MySQL SELECT 按组最频繁)...
2024-04-16 数据库问题
16

在 Group By 查询中包含缺失的月份
Include missing months in Group By query(在 Group By 查询中包含缺失的月份)...
2024-04-16 数据库问题
12