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

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

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

全部评论

相关推荐

来,说点可能被同行“骂”的大实话。🙊当初接数字马力Offer时,朋友都说:“蚂蚁的“内包”公司?你想清楚啊!”但入职快一年后的今天,我反而对他有了不一样的看法!🔹&nbsp;是偏见?还是信息差!之前没入职之前外面都在说什么岗位低人一等这类。实际上:这种情况不可至否,不能保证每个团队都是其乐融融。但我在的部门以及我了解的周边同事都还是十分好相处的~和蚂蚁师兄师姐之间也经常开一些小玩笑。总之:身份是蚂蚁公司给的,地位是自己挣的(一个傲娇女孩的自述)。🔹&nbsp;待遇?玩的就是真实!试用期工资全额发!六点下班跑得快(早9晚6或者早10晚7,动态打卡),公积金顶格交。别听那些画饼的,到手的钱和下班的时间才是真的(都是牛马何必难为牛马)。🔹&nbsp;能不能学到技术?来了就“后悔”!我们拥有权限直通蚂蚁知识库,技术栈多到学不完。说“学不到东西”的人,来了可能后悔——后悔来晚了(哈哈哈哈,可以不学但是不能没有)!💥&nbsp;内推地址:https://app.mokahr.com/su/ueoyhg❗我的内推码:NTA6Nvs走我的内推,可以直达业务部门,面试流程更快速,进度可查!今天新放HC,之前挂过也能再战!秋招已经正式开始啦~机会就摆在这,敢不敢来试一试呢?(和我一样,做个勇敢的女孩)
下午吃泡馍:数字马力的薪资一般哇,5年经验的java/测试就给人一万出头,而且刚入职第三天就让人出差,而且是出半年
帮你内推|数字马力 校招
点赞 评论 收藏
分享
10-01 09:50
门头沟学院 Java
肖先生~:这个人真的很好,点赞
点赞 评论 收藏
分享
评论
点赞
1
分享

创作者周榜

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