SELECT query return 1 row from each group(SELECT 查询从每组返回 1 行)
问题描述
这是一个产品表,有几百万条记录.
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_INCREMENT
ed).
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_INCREMENT
ed) 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 演示
为了获得更好的性能,请确保在这些列上有一个索引:ID
和 store_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 行的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:SELECT 查询从每组返回 1 行


- 远程 mySQL 连接抛出“无法使用旧的不安全身份验证连接到 MySQL 4.1+"来自 XAMPP 的错误 2022-01-01
- 更改自动增量起始编号? 2021-01-01
- SQL 临时表问题 2022-01-01
- 以一个值为轴心,但将一行上的数据按另一行分组? 2022-01-01
- 使用 Oracle PL/SQL developer 生成测试数据 2021-01-01
- 如何将 Byte[] 插入 SQL Server VARBINARY 列 2021-01-01
- 如何使用 pip 安装 Python MySQLdb 模块? 2021-01-01
- 导入具有可变标题的 Excel 文件 2021-01-01
- 如何将 SonarQube 6.7 从 MySQL 迁移到 postgresql 2022-01-01
- 在SQL中,如何为每个组选择前2行 2021-01-01