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%内容,订阅专栏后可继续查看/也可单篇购买

数据分析面试宝典 文章被收录于专栏

本面试宝典均来自校招面试题目大数据进行的整理

全部评论

相关推荐

程序员花海_:项目描述写的太少了 多写一点 先写业务 再写技术
点赞 评论 收藏
分享
评论
点赞
1
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务