SQL-1
1、UNION和JOIN的区别(滴滴、京东)
参考答案
UNION是两张表进行上下拼接,产生的两个记录集(字段要一样的)并在一起,成为一个新的记录集,分为UNION和UNION ALL两种方法;JOIN 是两张表进行左右连接,条件匹配的记录将合并产生一个记录集,有LEFT JOIN、RIGHT JOIN、INNER JOIN、OUTER JOIN等多种方法。
答案解析
(1)UNION
UNION 操作符用于合并两个或多个 SELECT 语句的结果集。UNION 内部的每个 SELECT 语句必须拥有相同数量的列。列也必须拥有相似的数据类型。同时,每个 SELECT 语句中的列的顺序必须相同。UNION 结果集中的列名总是等于 UNION 中第一个 SELECT 语句中的列名。若要对结果去重,可用 UNION 方法;如果允许存在重复的值,使用 UNION ALL。
示例:
table1:
table2:
要求:从 table1 和 table2 中选取所有的中国(CN)的数据(允许存在重复的值)
SELECT country, name FROM table1 WHERE country='CN' UNION ALL SELECT country, app_name as name FROM table2 WHERE country='CN'
结果:
(2)JOIN
JOIN 用于把来自两个或多个表的行结合起来。下图展示了 LEFT JOIN、RIGHT JOIN、INNER JOIN、OUTER JOIN 相关的 7 种用法。
2、Sql题目,求连续访问ID(猿辅导)
参考答案
现有用户访问登陆表log_table,记录了usr_id和访问日期:
求连续访问ID的问题可以转化为寻找有过连续3天以上访问记录usr_id的问题,具体代码如下:
SELECT DISTINCT usr_id
FROM(
SELECT usr_id
, DATE_SUB(log_dte, INTERVAL rank_id DAY) AS flg_dte
FROM(
SELECT usr_id, log_dte, dense_rank() over(partion by usr_id order by log_dte) rank_id
FROM log_table
) A
GROUP BY usr_id, flg_dte
HAVING COUNT(DISTINCT log_dte) >= 3
) B;
3、sql窗口函数并举例(滴滴、网易)
参考答案
1.窗口函数
窗口函数和普通聚合函数的区别:
①聚合函数是将多条记录聚合为⼀条;窗⼝函数是每条记录都会执行,有几条记录执行完还是几条。
②聚合函数也可以⽤于窗⼝函数。
原因就在于窗⼝函数的执⾏顺序(逻辑上的)是在FROM,JOIN,WHERE, GROUP BY,HAVING之后,在ORDER BY,LIMIT,SELECT DISTINCT之前。它 执⾏时GROUP BY的聚合过程已经完成了,所以不会再产⽣数据聚合。
注:窗口函数是在where之后执行的,所以如果where子句需要用窗口函数作为条件,需要多⼀层查询,在子查询外面进行,例如:
select user_id,avg(diff)
from
(
select user_id,lead(log_time)over(partition user_id order by
log_time) - log_time as diff
from user_log
)t
where datediff(now(),t.log_time)<=30
group by user_id
剩余60%内容,订阅专栏后可继续查看/也可单篇购买
本面试宝典均来自校招面试题目大数据进行的整理

vivo公司福利 364人发布