SQL学习之路(三)

本文讲解了如何创建SQL视图进行商品价格筛选、平均价计算,并讨论了NULL值处理及CASE语句在分类中的应用。通过实例展示了低、中、高档商品数量统计。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

CREATE VIEW view_name AS ViewPractice5_1
SELECT product_name, sale_price, regist_date FROM product
WHERE sale_price >= '1000' AND regist_date = '2009-09-20'

答:VIEW cannot use INSERT keyword.

SELECT product_id, 
product_name, 
product_type, 
sale_price, 
SUM(sale_price) / COUNT(*)  AS sale_price_all #这里导致只有一行,需要用子查询
FROM product

修正:

SELECT product_id, 
		product_name, 
		product_type, 
		sale_price, 
		(SELECT AVG(sale_price) FROM product )AS sale_price_all #这里导致只有一行,需要用子查询
FROM product

3.4

CREATE VIEW productsum (product_id, 
		product_name, 
		product_type, 
		sale_price, 
		avg_sale_price)
AS
SELECT product_id, 
		product_name, 
		product_type, 
		sale_price, 
		(SELECT AVG(sale_price) FROM product AS p2
         WHERE p1.product_type = p2.product_type
别忘了还要GROUP BY p2.product_type) AS avg_sale_price 
FROM product as p1	

3.5

运算或者函数中含有 NULL 时,结果全都会变为NULL ?(判断题)
答:会出错吧(×)正确

3.6

1.除掉三个价格的商品,然后显示
2.NULL的也除掉?
谓词不能包含NULL,否则会出错,
所以第一问不显示NULL的商品,第二问出错

3.7

按照销售单价( sale_price)对练习 6.1 中的 product(商品)表中的商品进行如下分类。
低档商品:销售单价在1000日元以下(T恤衫、办公用品、叉子、擦菜板、 圆珠笔)
中档商品:销售单价在1001日元以上3000日元以下(菜刀)
高档商品:销售单价在3001日元以上(运动T恤、高压锅)
请编写出统计上述商品种类中所包含的商品数量的 SELECT 语句,结果如下所示。
执行结果
low_price | mid_price | high_price
----------±----------±-----------
5 | 1 | 2

SELECT SUM(CASE WHEN sale_price < 1000 THEN 1 ELSE 0 END) AS low_price,
		SUM(CASE WHEN sale_price BETWEEN 1001 AND 3000  THEN 1 ELSE 0 END) AS mid_price,
		SUM(CASE WHEN sale_price >= 3001  THEN 1 ELSE 0 END) AS high_price
FROM product;  
  • 数值可以直接比较,不需要加单引号,单引号是文本、日期
  • 列转行,行转列,可以用CASE,这里的例子非常精辟,可以参考原文
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值