[SQL]数据分析SQL笔试题

SQL笔试题

1、请简单写出left join和join的用法区别(可举例说明);

join用于把来自两个或多个表的行结合起来,基于这些表之间的共同字段;

left join 关键字从左表(table1)返回所有的行,即使右表(table2)中没有匹配。如果右表中没有匹配,则结果为NULL。

如下使用例子来说明:

2、求出订单表(order_table表)中每个客户(custid)的最近一次购买日期(要求:按custid降序排列,transdate显示年月日格式);

[SQL]数据分析SQL笔试题_第1张图片

 本题的考察点主要有max()、STR_TO_DATE()、GROUP BY、ORDER BY 和DESC函数

SELECT custid, MAX(STR_TO_DATE(a.order_date,'%Y-%m-%d')) order_date 
FROM order_table as a 
GROUP BY custid 
ORDER BY custid DESC;

3、用一条SQL语句查出订单表(product表)购买的每类产品付款都大于60元的客户姓名;

[SQL]数据分析SQL笔试题_第2张图片

此题的考察点有where 和 group by:如下的SQL语句可以查询出每一类产品对应付款都大于60元的客户姓名:

SELECT product as 产品,name as 客户 FROM order_product 
WHERE payment > 60
GROUP BY product,name
ORDER BY product; 

[SQL]数据分析SQL笔试题_第3张图片

4、请问‘SELECT 1/3’运行后能否得到结果0.33,如不能请给出正确的代码;

得到的结果是0.3333,正确的代码应该是

SELECT ROUND(1/3,2)

5、根据如下订单表,请使用sql语法,按购买时间统计出每天的新客人数和老客人数;

[SQL]数据分析SQL笔试题_第4张图片

名词定义如下:

新客:当天有购买,且之前没有购买的人为新客,新客人数+1;

老客:当天有购买,且之前也有购买的人为老客,老客人数+1;

 

6、根据如下左表具有3层关系的类目表,请使用sql语法,将数据展现成右表形式:

[SQL]数据分析SQL笔试题_第5张图片

转载于:https://www.cnblogs.com/lsyb-python/p/11083977.html

你可能感兴趣的:([SQL]数据分析SQL笔试题)