• <i id='FYSnd'><tr id='FYSnd'><dt id='FYSnd'><q id='FYSnd'><span id='FYSnd'><b id='FYSnd'><form id='FYSnd'><ins id='FYSnd'></ins><ul id='FYSnd'></ul><sub id='FYSnd'></sub></form><legend id='FYSnd'></legend><bdo id='FYSnd'><pre id='FYSnd'><center id='FYSnd'></center></pre></bdo></b><th id='FYSnd'></th></span></q></dt></tr></i><div id='FYSnd'><tfoot id='FYSnd'></tfoot><dl id='FYSnd'><fieldset id='FYSnd'></fieldset></dl></div>

        <bdo id='FYSnd'></bdo><ul id='FYSnd'></ul>
      <tfoot id='FYSnd'></tfoot>
      <legend id='FYSnd'><style id='FYSnd'><dir id='FYSnd'><q id='FYSnd'></q></dir></style></legend>
    1. <small id='FYSnd'></small><noframes id='FYSnd'>

        SELECT 查询从每组返回 1 行

        时间:2023-05-23

        <legend id='k1N5f'><style id='k1N5f'><dir id='k1N5f'><q id='k1N5f'></q></dir></style></legend>

              <tbody id='k1N5f'></tbody>

            <small id='k1N5f'></small><noframes id='k1N5f'>

              <bdo id='k1N5f'></bdo><ul id='k1N5f'></ul>
                  <tfoot id='k1N5f'></tfoot>

                • <i id='k1N5f'><tr id='k1N5f'><dt id='k1N5f'><q id='k1N5f'><span id='k1N5f'><b id='k1N5f'><form id='k1N5f'><ins id='k1N5f'></ins><ul id='k1N5f'></ul><sub id='k1N5f'></sub></form><legend id='k1N5f'></legend><bdo id='k1N5f'><pre id='k1N5f'><center id='k1N5f'></center></pre></bdo></b><th id='k1N5f'></th></span></q></dt></tr></i><div id='k1N5f'><tfoot id='k1N5f'></tfoot><dl id='k1N5f'><fieldset id='k1N5f'></fieldset></dl></div>
                  本文介绍了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 行的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

                  上一篇:为什么行通过“解释"返回?不等于count()? 下一篇:使用 sql 转义的动态 mysql 查询与准备好的语句一样安全吗?

                  相关文章

                    <bdo id='3DRHP'></bdo><ul id='3DRHP'></ul>

                  <tfoot id='3DRHP'></tfoot>
                  1. <legend id='3DRHP'><style id='3DRHP'><dir id='3DRHP'><q id='3DRHP'></q></dir></style></legend>
                    <i id='3DRHP'><tr id='3DRHP'><dt id='3DRHP'><q id='3DRHP'><span id='3DRHP'><b id='3DRHP'><form id='3DRHP'><ins id='3DRHP'></ins><ul id='3DRHP'></ul><sub id='3DRHP'></sub></form><legend id='3DRHP'></legend><bdo id='3DRHP'><pre id='3DRHP'><center id='3DRHP'></center></pre></bdo></b><th id='3DRHP'></th></span></q></dt></tr></i><div id='3DRHP'><tfoot id='3DRHP'></tfoot><dl id='3DRHP'><fieldset id='3DRHP'></fieldset></dl></div>
                  2. <small id='3DRHP'></small><noframes id='3DRHP'>