当前位置: 首页 > news >正文

优惠券网站cms建设巨量引擎广告投放平台代理

优惠券网站cms建设,巨量引擎广告投放平台代理,怎样做自己公司的网站,10个免费定制logo大家好,我是空空star,本篇带大家了解一道简单的力扣sql练习题。 文章目录前言一、题目:586. 订单最多的客户二、解题1.正确示范①提交SQL运行结果2.正确示范②提交SQL运行结果3.正确示范③提交SQL运行结果4.正确示范④提交SQL运行结果5.其他总…

大家好,我是空空star,本篇带大家了解一道简单的力扣sql练习题。

文章目录

  • 前言
  • 一、题目:586. 订单最多的客户
  • 二、解题
    • 1.正确示范①
      • 提交SQL
      • 运行结果
    • 2.正确示范②
      • 提交SQL
      • 运行结果
    • 3.正确示范③
      • 提交SQL
      • 运行结果
    • 4.正确示范④
      • 提交SQL
      • 运行结果
    • 5.其他
  • 总结


前言


一、题目:586. 订单最多的客户

表: Orders

+-----------------+----------+
| Column Name     | Type     |
+-----------------+----------+
| order_number    | int      |
| customer_number | int      |
+-----------------+----------+
Order_number是该表的主键。
此表包含关于订单ID和客户ID的信息。

编写一个SQL查询,为下了 最多订单 的客户查找 customer_number 。

测试用例生成后, 恰好有一个客户 比任何其他客户下了更多的订单。

查询结果格式如下所示。

示例 1:

输入: 
Orders 表:
+--------------+-----------------+
| order_number | customer_number |
+--------------+-----------------+
| 1            | 1               |
| 2            | 2               |
| 3            | 3               |
| 4            | 3               |
+--------------+-----------------+
输出: 
+-----------------+
| customer_number |
+-----------------+
| 3               |
+-----------------+

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

进阶: 如果有多位顾客订单数并列最多,你能找到他们所有的 customer_number 吗?

二、解题

1.正确示范①

提交SQL

select customer_number
from Orders
group by customer_number
order by count(1) desc limit 1;

运行结果

2.正确示范②

提交SQL

select customer_number from(select customer_number,row_number() over(order by num desc) colfrom(select customer_number,count(1) numfrom Ordersgroup by customer_number) u 
) u2 where col=1;

运行结果

3.正确示范③

提交SQL

select customer_number from(select customer_number,rank() over(order by num desc) colfrom(select customer_number,count(1) numfrom Ordersgroup by customer_number) u 
) u2 where col=1;

运行结果

4.正确示范④

提交SQL

select customer_number from(select customer_number,dense_rank() over(order by num desc) colfrom(select customer_number,count(1) numfrom Ordersgroup by customer_number) u 
) u2 where col=1;

运行结果

5.其他


总结

正确示范①思路:
通过group by 按照客户分组,计算出每个客户的订单数,再按订单数降序,取第一条的客户limit 1;
正确示范②思路:
通过group by 按照客户分组,计算出每个客户的订单数num,再通过row_number() over(order by num desc),取排名1;
正确示范③思路:
通过group by 按照客户分组,计算出每个客户的订单数num,再通过rank() over(order by num desc),取排名1;
正确示范④思路:
通过group by 按照客户分组,计算出每个客户的订单数num,再通过dense_rank() over(order by num desc),取排名1;
小结:
今天做的这两道题都可以用以下三个开窗函数,因为题目给的测试用例中不存在第一名的数量相同。掌握以下三个开窗函数应用场景还是非常多的。希望可以帮助到新手。
row_number:顺序排序;
rank:并列排序,会跳过重复的序号,比如序号为1、1、3;
dense_rank:并列排序,不会跳过重复的序号,比如序号为1、1、2。

http://www.yidumall.com/news/13828.html

相关文章:

  • 7 the wordpress广州百度首页优化
  • 服装搭配网站源码好看的html网页
  • 做企业网站10万起步关键词优化 搜索引擎
  • 网站建设窗口框架网站优化推广公司排名
  • 临海门户网站住房和城乡建设规划局windows7系统优化工具
  • 辽宁省住房和建设厅网站淘宝关键词排名查询工具免费
  • 免费自助搭建网站营销团队找产品合作
  • 一般网站用什么技术做的网址怎么弄
  • 淄博铭锐 网站建设苏州seo服务
  • 一个网站两个域名吗海南百度推广代理商
  • 免费的个人主页网站外贸接单平台
  • 南阳做网站哪个好电脑版百度网盘
  • 上海工程信息网市在建工程网宁波seo网络推广外包报价
  • 国家企业信息填报系统登录合肥seo
  • 荆州网站设计网站推广与优化方案
  • 织梦网站优化免费注册网站有哪些
  • 华硕路由器做网站网站建设公司开发
  • 大型网站开发技术百度网站登录入口
  • 网站建设功能表网站推广优化c重庆
  • 主网站下建立子目录站双桥seo排名优化培训
  • 做视频比较好的理财网站有哪些惠州seo排名优化
  • 网站建设和营销百度西安
  • 如何取消wordpress页脚郑州seo关键词排名优化
  • 南京企业建网站流程济南百度seo
  • 把网站从空间删除网址制作
  • 做网站有没有受骗过公司产品推广文案
  • 聊城做网站的公司资讯网站推广有哪些方式
  • 做展示型网站多少钱seo关键词排名优化系统源码
  • 云端做效果图的网站品牌网站建设制作
  • 郝友做的网站google网站增加关键词