"SQL常见大厂面试题及强化 - 7大类型,执行顺序与示例解析"
SQL常见大厂面试题 - 7大类型 1. 行转列 在某些情况下,需要将数据从行转换为列进行展示。这通常是通过使用PIVOT或UNPIVOT语句来实现的。PIVOT将行数据转换为列,而UNPIVOT则将列数据转换为行。 2. 连续N天登录 在处理用户登录数据时,经常需要统计连续N天登录的用户。这可以通过使用窗口函数和LAG函数来实现。使用LAG函数可以访问前一个行的数据,从而判断是否连续登录。 3. N日留存率 留存率是指在某个时间段内,用户保持活跃的比例。计算N日留存率通常需要跟踪用户的登录情况,并根据用户的首次登录时间计算不同日期的留存率。 4. 分组内Top前几 在处理数据时,有时需要找出每个分组内的前几个值。这可以通过使用窗口函数和RANK函数来实现。RANK函数可以对数据进行排名,然后可以使用WHERE子句筛选出前几个值。 5. 窗口函数 窗口函数是一种在查询结果上执行运算的方法。它可以对每一行数据计算一个与该行相关的结果,而不是根据整个查询结果计算。常见的窗口函数包括SUM、AVG、COUNT等。 6. 带条件的聚合统计 在进行聚合统计时,有时候需要根据条件对数据进行筛选。可以使用HAVING子句在GROUP BY之后对聚合结果进行筛选,从而实现按条件进行聚合统计。 SQL强化 1. SQL执行顺序 SQL语句的执行顺序可以影响查询结果和性能。一般而言,SQL语句的执行顺序是从FROM子句开始,依次经过JOIN、ON、WHERE、GROUP BY、SELECT、HAVING、DISTINCT、ORDER BY和LIMIT等步骤。 举例来说,对于以下语句: SELECT a.sex, b.city, count(1) as cnt, sum(salary) as sum1 FROM table1 a JOIN table2 b ON a.id=b.id WHERE a.name=b.name GROUP BY a.sex,b.city HAVING cnt>=2 ORDER BY a.sex,b.city LIMIT 10 先执行FROM子句加载table1和table2这两个表,然后进行JOIN操作,接着根据ON条件进行筛选,再使用WHERE子句进行进一步筛选,然后按a.sex和b.city进行分组,然后对每个分组计算count和sum,接着使用HAVING子句对计数结果进行筛选,最后按a.sex和b.city进行排序,并取前10条结果。 2. SELECT DISTINCT SELECT DISTINCT语句用于从查询结果中返回不重复的值。当使用SELECT DISTINCT时,数据库引擎会从多个结果中去除重复的行。 例如: SELECT DISTINCT a.sex, b.city, a.age FROM table1 a JOIN table2 b ON a.id=b.id WHERE a.name=b.name 此查询将返回不重复的a.sex、b.city和a.age的组合。 总结: SQL常见大厂面试题可以分为7大类型:行转列、连续N天登录、N日留存率、分组内Top前几、窗口函数、带条件的聚合统计和SQL执行顺序。在面试中,掌握这些常见问题的解决方法是非常重要的。同时,在进行SQL查询时,也要了解SQL语句的执行顺序,以便更好地理解查询结果。
剩余29页未读,继续阅读
- 粉丝: 320
- 资源: 2
- 我的内容管理 收起
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
会员权益专享
最新资源
- zigbee-cluster-library-specification
- JSBSim Reference Manual
- c++校园超市商品信息管理系统课程设计说明书(含源代码) (2).pdf
- 建筑供配电系统相关课件.pptx
- 企业管理规章制度及管理模式.doc
- vb打开摄像头.doc
- 云计算-可信计算中认证协议改进方案.pdf
- [详细完整版]单片机编程4.ppt
- c语言常用算法.pdf
- c++经典程序代码大全.pdf
- 单片机数字时钟资料.doc
- 11项目管理前沿1.0.pptx
- 基于ssm的“魅力”繁峙宣传网站的设计与实现论文.doc
- 智慧交通综合解决方案.pptx
- 建筑防潮设计-PowerPointPresentati.pptx
- SPC统计过程控制程序.pptx
评论0