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,这里的例子非常精辟,可以参考原文