SQL数据工程师面试题20231226

1、数据库知识:

在这里插入图片描述

表一:Stock(商品库存入库表)
商品编号 入库数量 描述
A 300 A
B 400 B
C 200 C

注: Stock 表的商品编号是唯一主键。

表二: OutStock(商品库存出库表)

商品编号 出库数量 描述
A 100 A
B 40 B
B 50 B

注: outStock 表同一个商品存在多次出库。

– 创建 Stock 表
CREATE TABLE Stock (
商品编号 VARCHAR(10) PRIMARY KEY,
入库数量 INT,
描述 VARCHAR(255) );

– 插入数据到 Stock 表
INSERT INTO Stock (商品编号, 入库数量, 描述) VALUES (‘A’, 300, ‘A’), (‘B’, 400, ‘B’), (‘C’, 200, ‘C’);

– 创建 OutStock 表
CREATE TABLE OutStock (
商品编号 VARCHAR(10),
出库数量 INT,
描述 VARCHAR(255) );

– 插入数据到 OutStock 表 INSERT INTO OutStock (商品编号, 出库数量, 描述) VALUES (‘A’, 100, ‘A’), (‘B’, 40, ‘B’), (‘B’, 50, ‘B’);

1、请用一条 select 语句查询出每个商品的入库数量。

SELECT 商品编号, SUM(入库数量) AS 总入库数量
FROM Stock
GROUP BY 商品编号;

在这里插入图片描述

2、请用一条 select 语句查询出每个商品的出库数量:

SELECT 商品编号, COALESCE(SUM(出库数量), 0) AS 总出库数量
FROM OutStock
GROUP BY 商品编号;

#这里使用了COALESCE函数,它的作用是返回其参数中的第一个非NULL值。如果SUM(出库数量)的结果为NULL(可能是因为某些商品没有出库记录),则COALESCE函数会返回0,从而确保总出库数量始终有一个明确的值。
例如:

SQL实例

select coalesce(出库数量, 1) from OutStock

当“出库数量”为null值的时候,将返回1,否则将返回“出库数量”的真实值。

第二种写法:

SELECT
	商品编号,
	SUM(出库数量) AS 出库数量 
FROM
	OutStock 
GROUP BY
	商品编号;

在这里插入图片描述

3、请用一条 select 语句查询出剩余数量最大的商品编号:
*注:剩余数量 = 入库数量 - 出库数量

-- 从一个子查询中选择商品编号  
SELECT 商品编号  
FROM (  
    -- 子查询中首先从Stock表中选择商品编号,并计算每个商品的剩余数量  
    SELECT s.商品编号, (SUM(s.入库数量) - COALESCE(SUM(o.出库数量), 0)) AS 剩余数量  
    FROM Stock s -- 定义了一个别名s来表示Stock表  
    LEFT JOIN OutStock o ON s.商品编号 = o.商品编号 -- 使用LEFT JOIN连接Stock和OutStock表,连接条件是两个表中的商品编号相同  
    GROUP BY s.商品编号 -- 按商品编号进行分组,这样就可以对每个商品进行汇总计算  
) AS 剩余数量表 -- 给子查询结果起了一个别名"剩余数量表"  
ORDER BY 剩余数量 DESC -- 按剩余数量降序排序,这样剩余数量最大的商品会排在最前面  
LIMIT 1; -- 只取排序后的第一条记录,即剩余数量最大的商品编号

#简而言之,这段SQL代码首先通过子查询计算每个商品的剩余数量(入库数量减去出库数量),然后从这些结果中选取剩余数量最大的商品编号。

在这里插入图片描述

4、 请用一条 select 语句查询剩余数量:
*注:剩余数量 = 入库数量 - 出库数量

-- 从Stock表中选择商品编号和入库数量  
SELECT   
    Stock.商品编号,               -- 商品编号是唯一标识商品的字段  
    Stock.入库数量 - COALESCE(OutStock.出库数量, 0) AS 剩余数量  -- 入库数量减去出库数量得到剩余数量  
FROM   
    Stock                         -- 从Stock表开始查询  
LEFT JOIN (                       -- 使用LEFT JOIN连接一个子查询结果,该子查询计算每个商品的出库数量总和  
    SELECT   
        商品编号,                -- 商品编号用于分组,表示不同的商品  
        SUM(出库数量) AS 出库数量 -- 对每个商品的出库数量进行求和,得到该商品的出库总量  
    FROM   
        OutStock                -- 从OutStock表中选择数据  
    GROUP BY   
        商品编号                -- 按商品编号进行分组,这样就可以对每个商品进行汇总计算  
) AS OutStock                    -- 给子查询结果起了一个别名OutStock  
ON Stock.商品编号 = OutStock.商品编号; -- 使用商品编号作为连接条件,确保我们正确地将Stock表和子查询结果连接在一起

#这段SQL代码首先从Stock表中选择商品编号和入库数量。然后,它使用LEFT JOIN连接一个子查询结果,该子查询计算每个商品的出库数量总和。通过商品编号作为连接条件,确保我们正确地将Stock表和子查询结果连接在一起。最后,通过将入库数量与出库数量相减,得到每个商品的剩余数量。

在这里插入图片描述

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值