面试现场!月薪3w+的这些数据挖掘SQL面试题你都掌握了吗? ⛵

面试现场!月薪3w+的这些数据挖掘SQL面试题你都掌握了吗? ⛵

💡 作者:韩信子@ShowMeAI
📘 数据分析实战系列https://www.showmeai.tech/tutorials/40
📘 AI 面试题库系列https://www.showmeai.tech/tutorials/48
📘 本文地址https://www.showmeai.tech/article-detail/318
📢 声明:版权所有,转载请联系平台与作者并注明出处
📢 收藏ShowMeAI查看更多精彩内容

面试现场!月薪3w+的这些数据挖掘SQL面试题你都掌握了吗? ⛵

本篇内容基于场景面试题完成,在给定场景和数据表的前提下,有一系列的分析挖掘问题,大家可以基于SQL来完成。

场景:Danny非常喜欢日本料理,因此在 2021 年初,他决定冒险冒险,开了一家可爱的小餐厅,出售他最喜欢的 3 种食物:寿司、咖喱和拉面。这家餐厅从其几个月的运营中获取了一些非常基本的数据,但不知道如何使用他们的数据来帮助他们经营业务。

Danny 想基于收集到的数据来更深入地了解他的客户,例如他们的就餐模式、点餐花费以及他们最喜欢哪些菜等。下面你就来帮助他完成核心问题的分析吧,这里的分析基于SQL完成。

对于SQL更详尽的内容,欢迎大家查阅ShowMeAI制作的速查手册,快学快用:

💡 数据说明

本次的场景涉及到3个核心数据集,都已存入数据库表中:

  • sales
  • menu
  • members

这3张表对应的实体关系图如下所示:

面试现场!月薪3w+的这些数据挖掘SQL面试题你都掌握了吗? ⛵

📌 表1:Sales

销售额表对应的建表与数据插入SQL语句如下:

CREATE TABLE sales (
  "customer_id" VARCHAR(1),
  "order_date" DATE,
  "product_id" INTEGER
);

INSERT INTO sales
  ("customer_id", "order_date", "product_id")
VALUES
  ('A', '2021-01-01', '1'),
  ('A', '2021-01-01', '2'),
  ('A', '2021-01-07', '2'),
  ('A', '2021-01-10', '3'),
  ('A', '2021-01-11', '3'),
  ('A', '2021-01-11', '3'),
  ('B', '2021-01-01', '2'),
  ('B', '2021-01-02', '2'),
  ('B', '2021-01-04', '1'),
  ('B', '2021-01-11', '1'),
  ('B', '2021-01-16', '3'),
  ('B', '2021-02-01', '3'),
  ('C', '2021-01-01', '3'),
  ('C', '2021-01-01', '3'),
  ('C', '2021-01-07', '3');

面试现场!月薪3w+的这些数据挖掘SQL面试题你都掌握了吗? ⛵

菜单表对应的建表与数据插入SQL语句如下:

CREATE TABLE menu (
  "product_id" INTEGER,
  "product_name" VARCHAR(5),
  "price" INTEGER
);

INSERT INTO menu
  ("product_id", "product_name", "price")
VALUES
  ('1', 'sushi', '10'),
  ('2', 'curry', '15'),
  ('3', 'ramen', '12');

面试现场!月薪3w+的这些数据挖掘SQL面试题你都掌握了吗? ⛵

📌 表3:members

会员表对应的建表与数据插入SQL语句如下:

CREATE TABLE members (
  "customer_id" VARCHAR(1),
  "join_date" DATE
);

INSERT INTO members
  ("customer_id", "join_date")
VALUES
  ('A', '2021-01-07'),
  ('B', '2021-01-09');

面试现场!月薪3w+的这些数据挖掘SQL面试题你都掌握了吗? ⛵

💡 数据分析挖掘问题

📌 1.每位顾客在餐厅消费的总金额是多少?

这里的信息显然来源于sales和menu两张表,我们先对它们进行关联,而问题中的『每位顾客』意味着我们会基于 customer_id 进行分组统计。最后的SQL如下所示:

SELECT customer_id,
       Sum(price) AS total_sales
FROM   sales
       JOIN menu
         ON sales.product_id = menu.product_id
GROUP  BY sales.customer_id

查询结果如下:

面试现场!月薪3w+的这些数据挖掘SQL面试题你都掌握了吗? ⛵

📌 2.每位顾客光顾了餐厅多少天?

我们知道,每位顾客每次光顾,都会生成 sales 中的相关记录,我们可以基 customer_id统计客户访问餐厅的不同日期。

SELECT customer_id,
       Count(DISTINCT( order_date )) as no_of_days_customer_visited
FROM   sales
GROUP  BY customer_id

查询结果如下:

面试现场!月薪3w+的这些数据挖掘SQL面试题你都掌握了吗? ⛵

📌 3.每位顾客购买的菜单中的第一道菜是什么?

这个问题同样会涉及到 sales 和 menu 表,我们会用到 customer_idproduct_nameorder_date字段,按照要求,我们希望查询每个客户从菜单中购买的第 1 件商品,因此使用 rank 函数进行订单日期排序。对应的SQL如下所示:

WITH view_tab
     AS (SELECT customer_id,
                product_name,
                order_date,
                Rank()
                  OVER(
                    partition BY customer_id
                    ORDER BY order_date ) AS Ranking
         FROM   sales
                JOIN menu
                  ON sales.product_id = menu.product_id)
SELECT customer_id,
       product_name
FROM   view_tab
WHERE  ranking = 1
GROUP  BY customer_id,
          product_name

我们这里启用了临时表 view_tab,选择 ranking 位1的数据对应的 customer_idproduct_name

查询结果如下:

面试现场!月薪3w+的这些数据挖掘SQL面试题你都掌握了吗? ⛵

📌 4.菜单上购买最多的菜是什么,所有顾客购买了多少次?

这里很显然是以『菜』为核心,因此我们会基于 product_id进行分组,同时我们需要统计的是购买了多少次,因此需要根据 count(product_id)的结果进行排序,对应的SQL如下所示:

SELECT product_name,
       Count(sales.product_id) AS most_purchsed
FROM   sales
       JOIN menu
         ON sales.product_id = menu.product_id
GROUP  BY sales.product_id
ORDER  BY most_purchsed DESC
LIMIT  1

查询结果如下:

面试现场!月薪3w+的这些数据挖掘SQL面试题你都掌握了吗? ⛵

第2小问是问所有顾客在这个最热门的菜上下单的次数,我们在上述SQL的基础上加上 customer_id进行统计。

SELECT customer_id,
       product_name,
       Count(customer_id) AS purchase_count
FROM   sales
       JOIN menu
         ON sales.product_id = menu.product_id
WHERE  sales.product_id = 3
GROUP  BY customer_id
ORDER  BY purchase_count DESC

查询结果如下:

面试现场!月薪3w+的这些数据挖掘SQL面试题你都掌握了吗? ⛵

📌 5.每位顾客最喜欢的菜品分别是什么?

在这个问题中,我们要对客户购买每种产品的次数进行排名,因此使用窗口函数 rank,按 customer_id划分,按客户购买产品的次数(计数)排序。对应的SQL如下:

WITH view_tab
     AS (SELECT customer_id,
                product_name,
                Count(product_name)                    AS count_item,
                Rank()
                  OVER(
                    partition BY customer_id
                    ORDER BY Count(product_name) DESC) AS most_popular
         FROM   sales
                JOIN menu
                  ON sales.product_id = menu.product_id
         GROUP  BY customer_id,
                   product_name)
SELECT customer_id,
       product_name,
       count_item
FROM   view_tab
WHERE  most_popular = 1

查询结果如下:

面试现场!月薪3w+的这些数据挖掘SQL面试题你都掌握了吗? ⛵

📌 6.客户成为会员后最先购买的商品是什么?

这个问题中涉及到会员信息,我们会需要所有 3 个表,我们要把它们关联起来。我们要查询客户成为会员后购买的第一件商品,因此要选出订单日期需要大于加入日期的订单。使用窗口函数通过对 customer_id进行划分并按 order_date 对其进行排序,可以实现对第一个购买日期进行排序。这里依旧会需要借助临时表 view_tab。最终的SQL如下:

WITH view_tab
     AS (SELECT sales.customer_id,
                product_name,
                order_date,
                Rank()
                  OVER(
                    partition BY sales.customer_id
                    ORDER BY order_date) AS first_order
         FROM   sales
                JOIN menu
                  ON sales.product_id = menu.product_id
                JOIN members
                  ON sales.customer_id = members.customer_id
         WHERE  join_date

查询结果如下:

面试现场!月薪3w+的这些数据挖掘SQL面试题你都掌握了吗? ⛵

📌 7.在客户成为会员之前最后购买的是哪件菜品?

同上一个问题,我们需要用到所有 3 个表。要查询客户在成为会员之前购买的商品,订单日期需要小于加入日期。使用窗口函数通过对 customer_id进行划分并按 order_date对其进行排序,对第一个购买日期进行降序排列。最终的SQL如下:

WITH rank
     AS (SELECT S.customer_id,
                M.product_name,
                Dense_rank()
                  OVER (
                    partition BY S.customer_id
                    ORDER BY S.order_date) AS Rank
         FROM   sales S
                JOIN menu M
                  ON m.product_id = s.product_id
                JOIN members Mem
                  ON Mem.customer_id = S.customer_id
         WHERE  S.order_date < Mem.join_date)
SELECT customer_id,
       product_name
FROM   rank
WHERE  rank = 1

查询结果如下:

面试现场!月薪3w+的这些数据挖掘SQL面试题你都掌握了吗? ⛵

📌 8.每位会员入会前的总消费项目和消费金额是多少?

要查询客户在成为会员之前购买的总商品和花费的金额,订单日期需要小于入会日期。将 customer_id 的计数命名为 total_items,将消费金额price的总和命名为 total_sales,最终的SQL如下:

SELECT sales.customer_id,
       Count(sales.product_id) AS total_items,
       Sum(price)              AS total_sales
FROM   sales
       JOIN menu
         ON sales.product_id = menu.product_id
       JOIN members
         ON sales.customer_id = members.customer_id
WHERE  join_date > order_date
GROUP  BY sales.customer_id
ORDER  BY sales.customer_id

查询结果如下:

面试现场!月薪3w+的这些数据挖掘SQL面试题你都掌握了吗? ⛵

📌 9.如果每消费 1 美元累计10积分,寿司消费有 2 倍积分——每位顾客会有多少积分?

这个问题用到sales和menu两张表。我们使用case语句将积分分配给客户购买的商品,并对积分进行统计求和得到每位顾客的积分数。对应的SQL如下:

WITH view_tab
     AS (SELECT customer_id,
                CASE
                  WHEN product_name = 'sushi' THEN price * 20
                  ELSE price * 10
                END AS points
         FROM   sales
                JOIN menu
                  ON sales.product_id = menu.product_id)
SELECT customer_id,
       Sum(points) AS total_points
FROM   view_tab
GROUP  BY customer_id

查询结果如下:

面试现场!月薪3w+的这些数据挖掘SQL面试题你都掌握了吗? ⛵

📌 10.在客户加入计划后的第一周(包含入会日期),寿司和其他所有商品都是2倍积分,这种情况下1月份结束后客户有多少积分?

WITH dates
     AS (SELECT *,
                Dateadd(day, 6, join_date) AS valid_date,
                Eomonth('2021-01-31')      AS last_date
         FROM   members)
SELECT S.customer_id,
       Sum(CASE
             WHEN m.product_id = 1 THEN m.price * 20
             WHEN S.order_date BETWEEN D.join_date AND D.valid_date THEN
             m.price * 20
             ELSE m.price * 10
           END) AS Points
FROM   dates D
       JOIN sales S
         ON D.customer_id = S.customer_id
       JOIN menu M
         ON M.product_id = S.product_id
WHERE  S.order_date < d.last_date
GROUP  BY S.customer_id

查询结果如下:

面试现场!月薪3w+的这些数据挖掘SQL面试题你都掌握了吗? ⛵

📌 11.构建新的宽表,包含这些字段信息:customer_id, order_date, product_name, price, member [Y/N]

SELECT s.customer_id,
       s.order_date,
       m.product_name,
       m.price,
       CASE
         WHEN mb.join_date > s.order_date THEN 'N'
         WHEN mb.join_date

查询结果如下:

面试现场!月薪3w+的这些数据挖掘SQL面试题你都掌握了吗? ⛵

📌 12.对客户点菜菜品按时间先后编码,区分会员与非会员状态,非会员的菜品不计入顺序编码,记为NULL。

WITH joined_table
     AS (SELECT s.customer_id,
                s.order_date,
                m.product_name,
                m.price,
                CASE
                  WHEN mb.join_date > s.order_date THEN 'N'
                  WHEN mb.join_date

查询结果如下:

面试现场!月薪3w+的这些数据挖掘SQL面试题你都掌握了吗? ⛵

参考资料

面试现场!月薪3w+的这些数据挖掘SQL面试题你都掌握了吗? ⛵

Original: https://www.cnblogs.com/showmeai/p/16627827.html
Author: ShowMeAI
Title: 面试现场!月薪3w+的这些数据挖掘SQL面试题你都掌握了吗? ⛵

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/504918/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

  • 小公司比较吃亏的两道微服务面试题

    其实选择工作的时候,很多技术牛人都会选择一些小而美的公司,技术全面,能够以一个更全面的视角看整个公司的运作,人和人之间的相处也很简单。但是,有两道微服务的面试题,小公司的朋友们会比…

    数据库 2023年6月6日
    0135
  • MySQL日期时间函数一网打尽

    获取时间 函数 功能 返回格式 CURDATE(), CURRENT_DATE() 返回当前日期,只包含年、月、日 2022-03-08 CURTIME(), CURRENT_TI…

    数据库 2023年6月9日
    071
  • MySQL基础入门学习教程,带你快速掌握mysql

    Original: https://www.cnblogs.com/chaichaichai/p/15243386.htmlAuthor: 牛仔码农Title: MySQL基础入门…

    数据库 2023年5月24日
    0116
  • 我的第一本算法书 第一章

    1.1 决定数据顺序和位置关系的是数据结构 电话簿的数据结构 按获取顺序排序 按拼音顺序排序 添加简单 查询麻烦 查询简单 添加麻烦 两者结合 分别使用不同的表存储不同的首字母, …

    数据库 2023年6月11日
    098
  • Centos7安装Docker

    一、docker运行流程 举个例子你想使用MySQL镜像,那么执行docker pull 下载镜像的时候 首先它会在本地仓库进行运行,如果本地仓库有你想要的MySQL镜像 那么它会…

    数据库 2023年6月14日
    0121
  • ReentrantLock 公平锁源码 第1篇

    ReentrantLock 1 这篇还是接着ReentrantLock的公平锁,没看过第0篇的可以先去看上一篇https://www.cnblogs.com/sunankang/p…

    数据库 2023年6月16日
    0115
  • 001从零开始入门Entity Framework Core——基础知识

    1、对于 EF Core,使用模型执行数据访问。 模型由 实体类和表示数据库会话的 上下文对象构成。 上下文对象允许查询并保存数据。 2、EF 支持以下模型开发方法: 从现有数据库…

    数据库 2023年6月14日
    096
  • 从生命周期的角度看线程和进程之间的异同

    概述 进程与线程想必都不陌生,两者有诸多相同点,甚至可以这样说,线程就是”轻量级的进程”。而且两者基本的五个状态也几乎一样,但进程和线程在状态切换时的触发条…

    数据库 2023年6月11日
    087
  • django中的视图层

    1.什么是视图层 简单来说,就是用来接收路由层传来的请求,从而做出相应的响应返回给浏览器 2.视图层的格式与参数说明 2.1基本格式 from django.http import…

    数据库 2023年6月14日
    074
  • 4. 事务和锁

    404. 抱歉,您访问的资源不存在。 可能是URL不正确,或者对应的内容已经被删除,或者处于隐私状态。 [En] It may be that the URL is incorre…

    数据库 2023年5月24日
    083
  • Xtrabackup 8.0.x关于MySQL的版本支持的浅析

    我们知道从MySQL 8.0.x开始,我们必须用Percona Xtrabackup 8.0.x来备份,之前的Percona XtraBackup 2.4已经不支持MySQL 8….

    数据库 2023年5月24日
    0152
  • 浏览器书签插件配置

    准备远程Git仓库(目前只支持Gitee) 登录后创建仓库(如没有账号请自行注册) 配置Token 进入设置页面配置私人令牌 新增一个令牌(权限) 保存好生成的令牌,此令牌后续无法…

    数据库 2023年6月9日
    089
  • CSS进阶内容——布局技巧和细节修饰

    CSS进阶内容——布局技巧和细节修饰 我们在之前的文章中已经掌握了CSS的大部分内容,但仍有一些内容我们没有涉略,这篇文章就是为了补充前面没有涉及的内容,为我们的知识做出补充并且介…

    数据库 2023年6月14日
    083
  • AQS源码探究之竞争锁资源

    AQS源码探究—竞争锁资源 我们进入ReentrantLock源码中查看其内部类 Sync 对AQS进行扩展公共方法并定义抽象方法的抽象类 FaireSync 实现公平…

    数据库 2023年6月11日
    091
  • Spring(一)-初识 + DI+scope

    1、获取bean实例的三种方式 UTF-8 4.3.18.RELEASE 1.16.18 4.11 org.springframework spring-beans ${sprin…

    数据库 2023年6月16日
    084
  • Typora加七牛云实现实时图片自动上传

    Typora加七牛云实现实时图片自动上传 前言: ​ Typora是一款轻便简洁的Markdown编辑器,支持即时渲染技术,这也是与其他Markdown编辑器最显著的区别.重点是免…

    数据库 2023年6月9日
    0195
亲爱的 Coder【最近整理,可免费获取】👉 最新必读书单  | 👏 面试题下载  | 🌎 免费的AI知识星球