20231228 SQL基础50题打卡

20231228 SQL基础50题打卡

1068. 产品销售分析 I


销售表 Sales

+-------------+-------+
| Column Name | Type  |
+-------------+-------+
| sale_id     | int   |
| product_id  | int   |
| year        | int   |
| quantity    | int   |
| price       | int   |
+-------------+-------+
(sale_id, year) 是销售表 Sales 的主键(具有唯一值的列的组合)。
product_id 是关联到产品表 Product 的外键(reference 列)。
该表的每一行显示 product_id 在某一年的销售情况。
注意: price 表示每单位价格。

产品表 Product

+--------------+---------+
| Column Name  | Type    |
+--------------+---------+
| product_id   | int     |
| product_name | varchar |
+--------------+---------+
product_id 是表的主键(具有唯一值的列)。
该表的每一行表示每种产品的产品名称。

编写解决方案,以获取 Sales 表中所有 sale_id 对应的 product_name 以及该产品的所有 yearprice

返回结果表 无顺序要求

结果格式示例如下。

示例 1:

输入:
Sales 表:
+---------+------------+------+----------+-------+
| sale_id | product_id | year | quantity | price |
+---------+------------+------+----------+-------+ 
| 1       | 100        | 2008 | 10       | 5000  |
| 2       | 100        | 2009 | 12       | 5000  |
| 7       | 200        | 2011 | 15       | 9000  |
+---------+------------+------+----------+-------+
Product 表:
+------------+--------------+
| product_id | product_name |
+------------+--------------+
| 100        | Nokia        |
| 200        | Apple        |
| 300        | Samsung      |
+------------+--------------+
输出:
+--------------+-------+-------+
| product_name | year  | price |
+--------------+-------+-------+
| Nokia        | 2008  | 5000  |
| Nokia        | 2009  | 5000  |
| Apple        | 2011  | 9000  |
+--------------+-------+-------+
# Write your MySQL query statement below
select Product.product_name ,Sales.year , Sales.price from Sales, Product where Product.product_id = Sales.product_id;

1581. 进店却未进行过交易的顾客


表:Visits

+-------------+---------+
| Column Name | Type    |
+-------------+---------+
| visit_id    | int     |
| customer_id | int     |
+-------------+---------+
visit_id 是该表中具有唯一值的列。
该表包含有关光临过购物中心的顾客的信息。

表:Transactions

+----------------+---------+
| Column Name    | Type    |
+----------------+---------+
| transaction_id | int     |
| visit_id       | int     |
| amount         | int     |
+----------------+---------+
transaction_id 是该表中具有唯一值的列。
此表包含 visit_id 期间进行的交易的信息。

有一些顾客可能光顾了购物中心但没有进行交易。请你编写一个解决方案,来查找这些顾客的 ID ,以及他们只光顾不交易的次数。

返回以 任何顺序 排序的结果表。

返回结果格式如下例所示。

示例 1:

输入:
Visits
+----------+-------------+
| visit_id | customer_id |
+----------+-------------+
| 1        | 23          |
| 2        | 9           |
| 4        | 30          |
| 5        | 54          |
| 6        | 96          |
| 7        | 54          |
| 8        | 54          |
+----------+-------------+
Transactions
+----------------+----------+--------+
| transaction_id | visit_id | amount |
+----------------+----------+--------+
| 2              | 5        | 310    |
| 3              | 5        | 300    |
| 9              | 5        | 200    |
| 12             | 1        | 910    |
| 13             | 2        | 970    |
+----------------+----------+--------+
输出:
+-------------+----------------+
| customer_id | count_no_trans |
+-------------+----------------+
| 54          | 2              |
| 30          | 1              |
| 96          | 1              |
+-------------+----------------+
解释:
ID = 23 的顾客曾经逛过一次购物中心,并在 ID = 12 的访问期间进行了一笔交易。
ID = 9 的顾客曾经逛过一次购物中心,并在 ID = 13 的访问期间进行了一笔交易。
ID = 30 的顾客曾经去过购物中心,并且没有进行任何交易。
ID = 54 的顾客三度造访了购物中心。在 2 次访问中,他们没有进行任何交易,在 1 次访问中,他们进行了 3 次交易。
ID = 96 的顾客曾经去过购物中心,并且没有进行任何交易。
如我们所见,ID 为 30 和 96 的顾客一次没有进行任何交易就去了购物中心。顾客 54 也两次访问了购物中心并且没有进行任何交易。
# Write your MySQL query statement below
select Visits.customer_id ,count(*) as count_no_trans  from Visits where Visits.visit_id not  in (select Transactions.visit_id from Transactions) group by Visits.customer_id;

# 解法2
SELECT customer_id, count(customer_id) count_no_trans
FROM Visits v
LEFT JOIN transactions t 
ON v.visit_id = t.visit_id
WHERE transaction_id IS NULL
GROUP BY customer_id;


197. 上升的温度


表: Weather

+---------------+---------+
| Column Name   | Type    |
+---------------+---------+
| id            | int     |
| recordDate    | date    |
| temperature   | int     |
+---------------+---------+
id 是该表具有唯一值的列。
该表包含特定日期的温度信息

编写解决方案,找出与之前(昨天的)日期相比温度更高的所有日期的 id

返回结果 无顺序要求

结果格式如下例子所示。

示例 1:

输入:
Weather 表:
+----+------------+-------------+
| id | recordDate | Temperature |
+----+------------+-------------+
| 1  | 2015-01-01 | 10          |
| 2  | 2015-01-02 | 25          |
| 3  | 2015-01-03 | 20          |
| 4  | 2015-01-04 | 30          |
+----+------------+-------------+
输出:
+----+
| id |
+----+
| 2  |
| 4  |
+----+
解释:
2015-01-02 的温度比前一天高(10 -> 25)
2015-01-04 的温度比前一天高(20 -> 30)
# Write your MySQL query statement below
# 解法1
select d1.id from Weather as d1, Weather as d2 where timestampdiff(day,d1.recordDate,d2.recordDate) = -1 and 
d1.temperature > d2.temperature ;
# 解法2
select today.id as Id
from Weather yesterday , Weather today
where yesterday.recordDate = date_sub(today.recordDate,INTERVAL  1 day)
and today.Temperature > yesterday.Temperature

这一题主要是时间函数的用法:

明白了,下面是每个函数的详细示例,涵盖了年、月、日、小时等不同时间单位的例子:

  1. TIMESTAMPDIFF():计算两个日期或时间的差异,并以指定的时间单位返回结果。

    • 计算两个日期之间的年份差:
    SELECT TIMESTAMPDIFF(YEAR, '2000-01-01', '2023-12-31');
    
    • 计算两个日期之间的月份差:
    SELECT TIMESTAMPDIFF(MONTH, '2023-01-01', '2023-12-31');
    
    • 计算两个日期之间的天数差:
    SELECT TIMESTAMPDIFF(DAY, '2023-01-01', '2023-12-31');
    
    • 计算两个日期之间的小时差:
    SELECT TIMESTAMPDIFF(HOUR, '2023-01-01 12:00:00', '2023-01-02 10:30:00');
    
  2. DATEDIFF():计算两个日期之间的天数差。

    • 计算两个日期之间的天数差:
    SELECT DATEDIFF('2023-12-31', '2023-01-01');
    
  3. TIMEDIFF():计算两个时间之间的差异。

    • 计算两个时间之间的时间差:
    SELECT TIMEDIFF('10:30:00', '08:15:00');
    

这些示例演示了如何使用不同的时间单位来计算日期和时间之间的差异,包括年、月、日、小时等单位。

<think>好的,我现在需要帮助用户找到SQL每日练习的第7天相关内容。用户之前提到他们想参与每日SQL练习,现在在寻找Day 7的习或内容。我需要根据用户提供的引用内容来辅助回答,但看起来引用中的内容可能不直接相关,不过还是需要尽量参考。 首先,查看用户提供的引用内容。引用[1]提到使用SQL Developer进行数据库对象浏览、运行SQL语句和脚本,编辑调试PL/SQL,以及运行报告。这可能与练习中的实际操作有关,比如使用SQL Developer进行练习。引用[2]强调了主键和外键的重要性,以及连接时的注意事项。这可能提示Day 7的练习可能涉及连接、主外键的使用,或者数据结构的操作。引用[3]关于算法改进和数据处理,可能间接相关,但可能不是直接针对SQL练习的内容。 接下来,我需要生成Day 7的SQL练习。通常,SQL的学习路径会从基础查询逐渐过渡到更复杂的操作,比如连接、聚合函数、子查询等。假设Day 7可能涉及JOIN操作,因为引用[2]提到了主键和外键在连接时的作用。因此,设计一个涉及多连接的目比较合理。 目示例可以是关于订单和客户,要求用户编写查询来获取特定信息,如每个客户的订单总数。这需要用到INNER JOIN和GROUP BY,还可能涉及聚合函数COUNT。这样的练习能帮助用户掌握连接和分组统计。 然后,相关问需要围绕这个练习展开。可能的问包括优化JOIN查询性能的方法,这可能涉及到索引的使用,而引用[2]中提到的主键自动创建索引,因此可以提到主键索引的作用。另一个问可以是处理没有订单的客户,这需要用到LEFT JOIN,进一步扩展用户的JOIN知识。第三个问可能涉及性能分析,比如EXPLAIN PLAN的使用,引用[1]提到的SQL Developer工具可以用来运行和调试SQL语句,这里可以建议使用工具分析查询计划。 需要确保回答的结构清晰,分步骤解释目和解答,同时引用相关引用内容。例如,在讨论主键和索引优化时,引用[2]的内容可以作为支持。在提到使用SQL Developer进行查询分析时,引用[1]的内容适用。 最后,验证回答是否符合用户的要求:使用正确的中文,LaTeX格式正确,生成相关问,并正确引用参考资料。确保没有使用任何markdown格式,行内公式用$...$,独立公式用$$...$$,但在这个回答中可能不需要公式,所以主要注意代码块和引用标识。</think>根据您的要求,以下是SQL每日练习第7天的模拟习,结合数据连接和主外键应用场景(参考引用[2]中关于主键连接的说明): ### SQL Daily Practice Day 7 **目:订单分析系统** 现有两个数据: ```sql CREATE TABLE customers ( customer_id INT PRIMARY KEY, -- 主键定义参考[^2] name VARCHAR(50), city VARCHAR(50) ); CREATE TABLE orders ( order_id INT PRIMARY KEY, customer_id INT, order_date DATE, amount DECIMAL(10,2), FOREIGN KEY (customer_id) REFERENCES customers(customer_id) ); ``` **任务1** 编写查询显示每个客户的订单总数,包含以下: `客户名称 | 所在城市 | 订单数量` **解答示例**: ```sql SELECT c.name AS 客户名称, c.city AS 所在城市, COUNT(o.order_id) AS 订单数量 FROM customers c LEFT JOIN orders o ON c.customer_id = o.customer_id GROUP BY c.customer_id, c.name, c.city; ``` **知识点说明**: 1. 使用`LEFT JOIN`确保没有订单的客户也会显示 2. 通过主键`customer_id`进行连接(主外键关系如引用[2]所述) 3. 聚合函数与分组配合使用
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

xwhking

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值