LeetCode MySQL 1336. 每次访问的交易次数

文章目录

    • 1. 题目
    • 2. 解题

1. 题目

表: Visits

+---------------+---------+
| Column Name   | Type    |
+---------------+---------+
| user_id       | int     |
| visit_date    | date    |
+---------------+---------+
(user_id, visit_date) 是该表的主键
该表的每行表示 user_id 在 visit_date 访问了银行

表: Transactions

+------------------+---------+
| Column Name      | Type    |
+------------------+---------+
| user_id          | int     |
| transaction_date | date    |
| amount           | int     |
+------------------+---------+
该表没有主键,所以可能有重复行
该表的每一行表示 user_id 在 transaction_date 完成了一笔 amount 数额的交易
可以保证用户 (user) 在 transaction_date 访问了银行 
(也就是说 Visits 表包含 (user_id, transaction_date))

银行想要得到银行客户在一次访问时的交易次数和相应的在一次访问时该交易次数的客户数量的图表

写一条 SQL 查询多少客户访问了银行但没有进行任何交易,多少客户访问了银行进行了一次交易等等

结果包含两列:

  • transactions_count: 客户在一次访问中的交易次数
  • visits_count: 在 transactions_count 交易次数下相应的一次访问时的客户数量
    transactions_count 的值从 0 到所有用户一次访问中的 max(transactions_count)

按 transactions_count 排序

下面是查询结果格式的例子:

Visits 表:
+---------+------------+
| user_id | visit_date |
+---------+------------+
| 1       | 2020-01-01 |
| 2       | 2020-01-02 |
| 12      | 2020-01-01 |
| 19      | 2020-01-03 |
| 1       | 2020-01-02 |
| 2       | 2020-01-03 |
| 1       | 2020-01-04 |
| 7       | 2020-01-11 |
| 9       | 2020-01-25 |
| 8       | 2020-01-28 |
+---------+------------+
Transactions 表:
+---------+------------------+--------+
| user_id | transaction_date | amount |
+---------+------------------+--------+
| 1       | 2020-01-02       | 120    |
| 2       | 2020-01-03       | 22     |
| 7       | 2020-01-11       | 232    |
| 1       | 2020-01-04       | 7      |
| 9       | 2020-01-25       | 33     |
| 9       | 2020-01-25       | 66     |
| 8       | 2020-01-28       | 1      |
| 9       | 2020-01-25       | 99     |
+---------+------------------+--------+
结果表:
+--------------------+--------------+
| transactions_count | visits_count |
+--------------------+--------------+
| 0                  | 4            |
| 1                  | 5            |
| 2                  | 0            |
| 3                  | 1            |
+--------------------+--------------+
* 对于 transactions_count = 0, 
* 		visits 中 (1, "2020-01-01"), (2, "2020-01-02"), 
* 			(12, "2020-01-01")(19, "2020-01-03") 
* 			没有进行交易,所以 visits_count = 4* 对于 transactions_count = 1, 
* 		visits 中 (2, "2020-01-03"), (7, "2020-01-11"), 
* 				(8, "2020-01-28"), (1, "2020-01-02") 
*(1, "2020-01-04") 进行了一次交易,
* 				所以 visits_count = 5* 对于 transactions_count = 2, 
* 			没有客户访问银行进行了两次交易,
* 			所以 visits_count = 0* 对于 transactions_count = 3, 
* 			visits 中 (9, "2020-01-25") 进行了三次交易,
* 			所以 visits_count = 1* 对于 transactions_count >= 4, 
* 			没有客户访问银行进行了超过3次交易,
* 			所以我们停止在 transactions_count = 3

如下是这个例子的图表:
在这里插入图片描述

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

2. 解题

  • 先生成第一列,多了没关系,一会筛选,注意加个0
select 0 transactions_count
union all
select row_number() over(order by transaction_date) transactions_count
from Transactions
  • with as 创建 临时表 t
select distinct v.user_id, visit_date, transaction_date,count(*) over(partition by user_id, visit_date, visit_date=transaction_date) times
from Visits v left join Transactions tr
on v.user_id=tr.user_id and v.visit_date=tr.transaction_date
{"headers": ["user_id", "visit_date", "transaction_date", "times"], 
"values": [
[1, "2020-01-01",  null,		1], 
[1, "2020-01-02", "2020-01-02", 1], 
[1, "2020-01-04", "2020-01-04", 1], 
[2, "2020-01-02",  null, 		1], 
[2, "2020-01-03", "2020-01-03", 1], 
[7, "2020-01-11", "2020-01-11", 1], 
[8, "2020-01-28", "2020-01-28", 1], 
[9, "2020-01-25", "2020-01-25", 3], 
[12, "2020-01-01", null, 		1], 
[19, "2020-01-03", null, 		1]]}
  • 统计数量
select 0 transactions_count, count(*) visits_count
from t
where transaction_date is null
union all
select times transactions_count, count(*) visits_count
from t
where transaction_date is not null
group by times
{"headers": ["transactions_count", "visits_count"], 
"values": [[0, 4], [1, 5], [3, 1]]}
  • 左连接,筛选数据
# Write your MySQL query statement below
with t as 
(select distinct v.user_id, visit_date, transaction_date,count(*) over(partition by user_id, visit_date, visit_date=transaction_date) timesfrom Visits v left join Transactions tron v.user_id=tr.user_id and v.visit_date=tr.transaction_date
)select t1.transactions_count, ifnull(t2.visits_count,0) visits_count
from
(select 0 transactions_countunion allselect row_number() over(order by transaction_date) transactions_countfrom Transactions
) t1 
left join 
(select 0 transactions_count, count(*) visits_countfrom twhere transaction_date is nullunion allselect times transactions_count, count(*) visits_countfrom twhere transaction_date is not nullgroup by times
) t2
on t1.transactions_count = t2.transactions_count
where t1.transactions_count <= (select max(transactions_count) from (select 0 transactions_count, count(*) visits_countfrom twhere transaction_date is nullunion allselect times transactions_count, count(*) visits_countfrom twhere transaction_date is not nullgroup by times) t3)

评论区简洁解答

# Write your MySQL query statement below
with temp1 as (select transactions_count, count(user_id) visits_countfrom (select v.user_id, count(t.user_id) transactions_countfrom Visits v left join Transactions ton v.user_id = t.user_id and visit_date = transaction_dategroup by v.user_id, v.visit_date) agroup by transactions_count
)select temp2.transactions_count, ifnull(temp1.visits_count,0) visits_count
from 
(select 0 transactions_countunionselect row_number() over (order by transaction_date) transactions_countfrom Transactions
) temp2 left join temp1
on temp2.transactions_count = temp1.transactions_count
where temp2.transactions_count <= (select max(transactions_count)from temp1)

我的CSDN博客地址 https://michael.blog.csdn.net/

长按或扫码关注我的公众号(Michael阿明),一起加油、一起学习进步!
Michael阿明

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/474519.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

python中if命令简单介绍及注意事项(含笔记)

if语句是用来进行判断的&#xff0c;其使用格式如下&#xff1a;

jQuery源码分析系列:事件模块概述

jQuery的事件模块是较复杂的&#xff0c;前面仅仅提到了对事件对象的包装。即统一了一些兼容性的问题。这篇会综述下jQuery的整个事件模块。后面会详细分析jQuery.event.add/jQuery.event.remove/jQuery.event.trigger。 虽然事件模块代码很难读&#xff0c;但其提供的API接口还…

LeetCode MySQL 1159. 市场分析 II(rank+over)

文章目录1. 题目2. 解题1. 题目 表: Users ------------------------- | Column Name | Type | ------------------------- | user_id | int | | join_date | date | | favorite_brand | varchar | ------------------------- user_id 是该表的主键…

python中elif和while简单介绍及注意事项(含笔记)

一、elif 想一想&#xff1a; if能完成当xxx时做事情&#xff1b;if-else能完成当xxx时做事情1&#xff0c;否则做事情2; 如果有这样一种情况&#xff1a;当xxx1时做事情1&#xff0c;当xxx2时做事情2&#xff0c;当xxx3时做事情3&#xff0c;那该怎么实现呢&#xff1f; 答…

LeetCode MySQL 262. 行程和用户

文章目录1. 题目2. 解题1. 题目 Trips 表中存所有出租车的行程信息。 每段行程有唯一键 Id&#xff0c;Client_Id 和 Driver_Id 是 Users 表中 Users_Id 的外键。 Status 是枚举类型&#xff0c;枚举成员为 (‘completed’, ‘cancelled_by_driver’, ‘cancelled_by_client’…

花了一年时间开发出来的基于DXF文件的加工路径自动生成软件

随着科技水平的进步&#xff0c;计算机辅助制造技术CAD/CAM在机械加工中起着越来越重要得作用,传统的手动编程正在被自动编程所取代&#xff0c;目前PRO/E,UG,MasterCAM等商业软件可以根据设计的图形直接生成数控加工代码。然而这些软件相对来说功能复杂&#xff0c;不易掌握&a…

LeetCode 1136. 平行课程(拓扑排序)

文章目录1. 题目2. 解题1. 题目 已知有 N 门课程&#xff0c;它们以 1 到 N 进行编号。 给你一份课程关系表 relations[i] [X, Y]&#xff0c;用以表示课程 X 和课程 Y 之间的先修关系&#xff1a;课程 X 必须在课程 Y 之前修完。 假设在一个学期里&#xff0c;你可以学习任…

【Android】Uri和Url和URN

最早在Android方面接触这两个概念&#xff0c;是学习ContentProvider的时候&#xff0c;当时花了很多时间&#xff0c;始终不能很好的理解他们的区别&#xff0c;顺带着ContentProvider的用法也无法理解&#xff0c;最近通过实现网页链接和Android-APP的无缝跳转问题&#xff0…

LeetCode 1259. 不相交的握手(DP)

文章目录1. 题目2. 解题1. 题目 偶数 个人站成一个圆&#xff0c;总人数为 num_people 。 每个人与除自己外的一个人握手&#xff0c;所以总共会有 num_people / 2 次握手。 将握手的人之间连线&#xff0c;请你返回连线不会相交的握手方案数。 由于结果可能会很大&#xf…

外星人装深度linux,17xR4深度拆机教程、加装MSATA固态硬盘及评测

本帖最后由 wellsyue 于 2012-6-20 20:45 编辑看到其他板块在三代IVY推出后&#xff0c;陆续发布了很多加装MSATA的帖子&#xff0c;发现外星人板块还没有17R4加装MSATA的帖子&#xff0c;在此&#xff0c;发布M17x R4加装MSATA教程一贴&#xff0c;既然是教程&#xff0c;就应…

LeetCode 248. 中心对称数 III(DFS/BFS)

文章目录1. 题目2. 解题2.1 DFS2.2 BFS1. 题目 中心对称数是指一个数字在旋转了 180 度之后看起来依旧相同的数字&#xff08;或者上下颠倒地看&#xff09;。 写一个函数来计算范围在 [low, high] 之间中心对称数的个数。 示例: 输入: low "50", high "10…

LeetCode 1067. 范围内的数字计数

文章目录1. 题目2. 解题1. 题目 给定一个在 0 到 9 之间的整数 d&#xff0c;和两个正整数 low 和 high 分别作为上下界。 返回 d 在 low 和 high 之间的整数中出现的次数&#xff0c;包括边界 low 和 high。 示例 1&#xff1a; 输入&#xff1a;d 1, low 1, high 13 输…

多参的实现原理

相信大家都使用过C语言的库函数&#xff1a;printf("%d%d", 1, 2)的吧&#xff0c;使用确实很方便功能也很强大。 但是为什么它可以接受多个参数呢&#xff1f; 现在我们来解析一下多参的实现原理&#xff0c;网上也找了一些文章。发现解析得都不全面。并且有BUG。 先…

学生成绩统计c语言课程设计,学生成绩管理系统-C语言课程设计

记一次课程设计作业 学生成绩管理系统#include#include#include#include/*学生成绩管理系统介绍2017C语言课程设计 2021609361.支持将数据保存到文件并从文件中读取已有数据2.支持添加、删改数据3.支持按学号或姓名查询、删除、修改数据4.支持简单统计&#xff0c;包括 不及格…