(202307)wonderful-sql:集合运算(task4)

教程链接:Datawhale - 一个热爱学习的社区

知识学习(随记)

  1. 从表的加减法中间的练习题可以看出,union不仅可以用于对两个表取并,也可以用于对同一个表的不同条件的筛选取并。
  2. 也可以用union测试数据的兼容性。
  3. mysql即使到了8.0,也还是有好些不支持的运算。

练习题

4.1 找出 product 和 product2 中售价高于 500 的商品的基本信息

sql 复制代码
SELECT *
  FROM Product
WHERE sale_price > 500
 UNION ALL
SELECT *
  FROM Product2
WHERE sale_price > 500;

4.2 借助对称差的实现方式, 求product和product2的交集

sql 复制代码
SELECT *
FROM
(SELECT * 
FROM product
UNION
SELECT *
From product2) u
WHERE product_id NOT IN
(SELECT product_id
FROM product
WHERE product_id NOT IN (SELECT product_id FROM product2)
UNION
SELECT product_id
FROM product2
WHERE product_id NOT IN (SELECT product_id FROM product));

4.3 每类商品中售价最高的商品都在哪些商店有售 ?

sql 复制代码
SELECT sp.shop_id, sp.shop_name, sp.product_id, p.product_type
FROM shopproduct sp
INNER JOIN product p
ON sp.product_id = p.product_id
WHERE sp.product_id IN 
(SELECT product_id
FROM product p1
INNER JOIN (SELECT product_type, MAX(sale_price) as max_price
FROM product
GROUP BY product_type) p2
ON p1.product_type = p2.product_type AND p1.sale_price=p2.max_price);

4.4 分别使用内连结和关联子查询每一类商品中售价最高的商品

内连结查询

sql 复制代码
SELECT product_name, product_type, sale_price
FROM product AS P1
WHERE sale_price = (SELECT MAX(sale_price)
FROM product AS P2
WHERE P1.product_type = P2.product_type)

关键子查询

sql 复制代码
SELECT P1.product_id, P1.product_name, P1.product_type, P1.sale_price, P1.max_price
FROM product AS P1
INNER JOIN (SELECT product_type, MAX(sale_price) AS max_price
FROM product
GROUP BY product_type) AS P2 ON P1.product_type = P2.product_type
WHERE P1.sale_price = P2.max_price

4.5 用关联子查询实现:在 product 表中,取出 product_id, product_name, sale_price, 并按照商品的售价从低到高进行排序、对售价进行累计求和。

sql 复制代码
SELECT product_id, product_name, sale_price,(SELECT SUM(sale_price)
FROM product p2 WHERE p2.sale_price <= p1.sale_price) AS cumulative_sum
FROM product p1
ORDER BY sale_price;
相关推荐
WeiQ_2 小时前
解决phpstudy 8.x软件中php8.2.9没有redis扩展的问题
数据库·redis·缓存
DashVector7 小时前
向量检索服务 DashVector产品计费
数据库·数据仓库·人工智能·算法·向量检索
KYGALYX8 小时前
在Linux中备份msyql数据库和表的详细操作
linux·运维·数据库
檀越剑指大厂8 小时前
金仓KReplay:定义数据库平滑迁移新标准
数据库
努力成为一个程序猿.8 小时前
【Flink】FlinkSQL-动态表和持续查询概念
大数据·数据库·flink
kali-Myon9 小时前
NewStarCTF2025-Week4-Web
sql·安全·web安全·php·ctf·ssti·ssrf
毕设十刻9 小时前
基于Vue的学分预警系统98k51(程序 + 源码 + 数据库 + 调试部署 + 开发环境配置),配套论文文档字数达万字以上,文末可获取,系统界面展示置于文末
前端·数据库·vue.js
liliangcsdn10 小时前
如何利用约束提示优化LLM在问题转sql的一致性
数据库·sql
Java爱好狂.10 小时前
分布式ID|从源码角度深度解析美团Leaf双Buffer优化方案
java·数据库·分布式·分布式id·es·java面试·java程序员