• 【SQL中limit的用法】


    SQL中limit的用法

    说明:limit子句用于限制查询结果返回的数量,常用于分页查询。

    用法:【select * from tableName limit i,n 】
    参数:tableName: 为数据表;
         i: 为查询结果的索引值(默认从0开始);
         n: 为查询结果返回的数量
    
    • 1
    • 2
    • 3
    • 4

    案例:(来自于力扣的一道简单题)

    表: Orders
    +-----------------+----------+
    | Column Name     | Type     |
    +-----------------+----------+
    | order_number    | int      |
    | customer_number | int      |
    +-----------------+----------+
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    Order_number是该表的主键。
    此表包含关于订单ID和客户ID的信息。

    编写一个SQL查询,为下了 最多订单 的客户查找 customer_number 。
    测试用例生成后, 恰好有一个客户 比任何其他客户下了更多的订单。
    查询结果格式如下所示。

    示例 1:
    输入:

    Orders 表:
    +--------------+-----------------+
    | order_number | customer_number |
    +--------------+-----------------+
    | 1            | 1               |
    | 2            | 2               |
    | 3            | 3               |
    | 4            | 3               |
    +--------------+-----------------+
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    输出:

    +-----------------+
    | customer_number |
    +-----------------+
    | 3               |
    +-----------------+
    
    • 1
    • 2
    • 3
    • 4
    • 5

    解释:
    customer_number 为 ‘3’ 的顾客有两个订单,比顾客 ‘1’ 或者 ‘2’ 都要多,因为他们只有一个订单。
    所以结果是该顾客的 customer_number ,也就是 3 。

    来源:力扣(LeetCode)
    链接:https://leetcode-cn.com/problems/customer-placing-the-largest-number-of-orders
    著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

    解答:
    首先,我们使用 GROUP BY 选择 customer_number 和相应的订单数目。

    SELECT
        customer_number, COUNT(*)
    FROM
        orders
    GROUP BY customer_number
    
    • 1
    • 2
    • 3
    • 4
    • 5

    customer_number

    COUNT(*)

    1

    1

    2

    1

    3

    2

    将它们按照订单数目降序排序之后,第一条记录的 customer_number 就是答案。

    customer_number

    COUNT(*)

    3

    2

    在 MySQL 中, LIMIT 语句可以被用来限制 SELECT 语句的返回行数。它需要传入 1 个或 2 个非负整数参数,第一个参数 offset 表示跳过前面多少行后开始取数据,第二个参数表示最多返回多少行的数据。默认 offset 为 0(不是 1)。
    LIMIT 语句也可以只使用一个参数,这个参数的含义是从结果的第一行开始返回的行数。所以 LIMIT 1 会返回第一行的记录。

    SELECT
        customer_number
    FROM
        orders
    GROUP BY customer_number
    ORDER BY COUNT(*) DESC
    LIMIT 1;
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    先自我介绍一下,小编13年上师交大毕业,曾经在小公司待过,去过华为OPPO等大厂,18年进入阿里,直到现在。深知大多数初中级java工程师,想要升技能,往往是需要自己摸索成长或是报班学习,但对于培训机构动则近万元的学费,着实压力不小。自己不成体系的自学效率很低又漫长,而且容易碰到天花板技术停止不前。因此我收集了一份《java开发全套学习资料》送给大家,初衷也很简单,就是希望帮助到想自学又不知道该从何学起的朋友,同时减轻大家的负担。添加下方名片,即可获取全套学习资料哦

  • 相关阅读:
    六级易混词整理
    【数据结构功法】第4话 · 手把手拉着你入门单链表
    【Linux】VMware下载和安装
    在PHP8中遍历数组-PHP8知识详解
    Vue学习笔记-配置代理服务器
    恼人的TCP套接字部分发送成功场景
    《Python趣味工具》——自制emoji3
    【OpenVINO™】在C#中使用 OpenVINO™ 部署 YOLOv10 模型实现目标
    嵌入式系统多线程学习笔记
    使用bisect模块进行二分查找操作 bisect.bisect()
  • 原文地址:https://blog.csdn.net/m0_67391121/article/details/126080686