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

湖南网站备案注销关键词检测

湖南网站备案注销,关键词检测,商务酒店设计网站建设,专业网站设计开发公司大家好,我是空空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.yayakq.cn/news/545456/

相关文章:

  • 企业内部网站如何建设网络网站建设10大指标
  • 网站推广的方法及技巧网站所有权包括
  • 网站logo设计标准赢了网站怎么做的
  • 网站字体一般大小分类信息系统网站模板
  • 营销网站有哪些陕西省建设厅网站证件查询
  • 茂名做网站建设公司wordpress侧边栏图和标题
  • 企业怎样选择域名做网站php的网站有哪些
  • 湘潭网站建设 w磐石网络装置艺术那个网站做的好
  • 网站如何做seo规划西昌网站建设公司
  • 中山网站免费制作wordpress 售后 插件
  • jquery做的网站想建个图片网站
  • 个人网站的留言板数据库怎么做做网站买什么书
  • 做网站点击软件html5写的网站有什么好处
  • 制作微信网站模板下载不了ftp wordpress 搬站
  • 手机网站怎么开发高端网站开发价格
  • 做彩票网站都是怎么拉人的成都市建管平台
  • 关于营销的网站有哪些怎么建设淘宝那样的网站
  • 企业网站建设排名网址用网站做的简历模板
  • 百度网站收录提交入口全攻略企业网站需求文档
  • 营销型网站的建站步骤是什么意思深圳教育 网站建设
  • 宝安印刷网站建设山西建设厅网站2016年3号文件
  • 用asp.net做购物网站国际网站平台
  • 危险网站怎么做二维码免费浏览器加速器
  • 新乡网站建设开发深圳免费网站排名优化
  • 如何制作自己的网站?链接
  • 找网站公司做网站的陷阱怎么查自己的二建信息
  • 怎么创建网站上海企业建站
  • 公章电子版在线制作网站哈尔滨做网站公司哪家好
  • 建设网站的效益分析wordpress页面显示什么意思
  • wordpress 归档文章网站代码优化的内容有哪些