阿里云瑶池数据库SQL大赛获奖名单及参考答案

简介: 阿里云瑶池数据库SQL大赛获奖名单及参考答案

阿里云瑶池数据库SQL挑战赛于6月19日正式落下帷幕。自5月份开赛以来,我们收到了100多份优秀的参赛作品,感谢各位社区朋友的参与!参赛作品评审采用“初评+终评”的方式,前期评审小组初评,终评技术专家审核的方式完成评审工作。最终评选出最佳 SQL 奖( 3位)、人气 SQL 奖(4位)、优质 SQL 奖(70位)现将获奖名单以及参考答案进行公布!

活动规则链接https://developer.aliyun.com/mission/activity/sql



1.最佳SQL奖

评奖规则:挑战三个赛题并给出正确结果截图+SQL 源码+解题思路的参与者可参与评选,根据提交时间、 SQL 写法、SQL 性能、解题思路综合评选3 位获奖者

恭喜以下用户获得Beats Studio Buds 耳机,我们将在三个工作日内通过阿里云开发者社区站内信收集获奖地址,请大家注意查收!

获奖人

赛题答案

(点击超链接查看详细内容)

综合用时


专家组评价

ug4nypj2jl7cm

玩法平台-阿里云数据库SQL挑战赛-任务组的测评

120ms

思路清晰,性能优越,考虑周全,解题思路也很清晰

1637228461567078

参与瑶池数据库SQL挑战赛的测评

134ms

代码很规整,格式很规范,性能优越,也用了高阶的SQL写法来做实现,值得大家学习

游客h42bnxufjiuea

参与瑶池数据库SQL挑战赛的测评

129ms

有高阶SQL使用方法,性能也很好,由于题目描述的原因对于第二题“首周”的理解有偏差,但是不影响对于题目的解答



2.人气SQL奖

评奖规则:挑战任意一个赛题并给出正确结果截图+SQL 源码+解题思路的参与者可参与评选,按作品点赞数排序,排名前三位的参与者。

恭喜以下用户获得小熊煮蛋器,我们将在三个工作日内通过1积分发送兑换资格,请大家关注社区积分待领取提

获奖人

赛题答案

(点击超链接查看详细内容)

点赞数量

CHENGANG

参与瑶池数据库SQL挑战赛的测评

21

辣辣滴小罗号

玩法平台-阿里云数据库SQL挑战赛-任务组的测评

16

nb@plus

参与瑶池数据库SQL挑战赛的测评

14

owen_wang2023

参与瑶池数据库SQL挑战赛的测评

14




3.优质SQL奖

评奖规则:挑战任意一个赛题并给出正确结果截图+SQL 源码+解题思路的参与者

恭喜以下70位用户获得20元猫超卡,我们将在三个工作日内通过短信进行发放,请大家注意查收!




4.阳光普照奖

评奖规则:挑战任意一个赛题并提交结果(不要求结果正确)+SQL 源码的参与者

所有提交作品通过了审核的参与者均可获得100积分,积分已在上周发放完毕,请大家到社区积分商城领取





阿里云瑶池数据库SQL大赛参考答案

注:大家可以根据给出的SQL以及解题思路跑出答案哦~


第一题

SELECT
  t.name AS Test,
  s.name AS Student,
  ta.score AS Score
FROM
  (
    SELECT
      testId,
      MAX(score) AS max_score
    FROM
      TestAttempt
    GROUP BY
      testId
  ) AS temp
  JOIN Test AS t ON temp.testId = t.id
  JOIN TestAttempt AS ta ON temp.testId = ta.testId
  AND temp.max_score = ta.score
  JOIN Student AS s ON ta.studentId = s.id
WHERE
  (
    SELECT
      COUNT(DISTINCT score)
    FROM
      TestAttempt
    WHERE
      testId = temp.testId
      AND score >= temp.max_score
  ) <= 3
ORDER BY
  t.name,
  ta.score DESC

解题思路:首先,筛选出每个学生在每门考试中的最高分,再将每个学生的最高分和其他学生的最高分进行对比,如果有更高分或平分的人的总数不超过三个,那么这个考生的最高分会被列入。


第二题

SELECT
  ROUND(CAST(repeat_players AS FLOAT) / total_players, 2) AS fraction
FROM
  (
    SELECT DISTINCT
      COUNT(DISTINCT a1.player_id) AS repeat_players,
      (
        SELECT
          COUNT(DISTINCT player_id)
        FROM
          Activity
      ) AS total_players
    FROM
      Activity a1
      JOIN (
        SELECT
          player_id,
          MIN(event_date) AS first_play_date
        FROM
          Activity
        GROUP BY
          player_id
      ) a2 ON a1.player_id = a2.player_id
    WHERE
      a1.event_date BETWEEN a2.first_play_date AND DATE_ADD(a2.first_play_date, INTERVAL 6 DAY)
      AND a1.games_played > 0
      AND a1.event_date <> a2.first_play_date
  ) t

解题思路:这题的重点是把所有首周内有至少两次登录的用户,因此,将所有玩家的游玩日期和他们首次游玩的日期进行比较,有在七天以内的进行记录。这边使用了MySQL的date interval,配合BETWEEN,7天之内的话应该是试用INTERVAL 6 DAY,但是使用INTERVAL 7 DAY的也算正确。


第三题

SELECT
    t.id,
    ROUND(SQRT(t.p*(t.p-t.a)*(t.p-t.b)*(t.p-t.c)), 2) AS area
FROM (
    SELECT 
        triangle.id,
        ROUND(SQRT(POWER(p1.x-p2.x,2)+POWER(p1.y-p2.y,2)+POWER(p1.z-p2.z,2)), 2) AS a,
        ROUND(SQRT(POWER(p1.x-p3.x,2)+POWER(p1.y-p3.y,2)+POWER(p1.z-p3.z,2)), 2) AS b,
        ROUND(SQRT(POWER(p2.x-p3.x,2)+POWER(p2.y-p3.y,2)+POWER(p2.z-p3.z,2)), 2) AS c,
        ROUND((ROUND(SQRT(POWER(p1.x-p2.x,2)+POWER(p1.y-p2.y,2)+POWER(p1.z-p2.z,2)),2)
             +ROUND(SQRT(POWER(p1.x-p3.x,2)+POWER(p1.y-p3.y,2)+POWER(p1.z-p3.z,2)),2)
             +ROUND(SQRT(POWER(p2.x-p3.x,2)+POWER(p2.y-p3.y,2)+POWER(p2.z-p3.z,2)),2))/2, 2) AS p
    FROM 
        triangle
        JOIN point p1 ON pointid1 = p1.id 
        JOIN point p2 ON pointid2 = p2.id
        JOIN point p3 ON pointid3 = p3.id
) t 
ORDER BY id;

使用海伦公式,要点在于数学公式的SQL实现,不作过多解释

目录
打赏
0
1
0
0
36
分享
相关文章
拒绝等待!阿里云瑶池数据库 x Qwen3,构建增强式RAG
阿里云瑶池 Dify on DMS + AnalyticDB 现已支持通义千问 Qwen3 全系列模型的私域部署,并提供独占模型服务,实现高效安全的 GraphRAG 业务应用及大模型应用开发解决方案。
大数据新视界--大数据大厂之MySQL数据库课程设计:MySQL 数据库 SQL 语句调优方法详解(2-1)
本文深入介绍 MySQL 数据库 SQL 语句调优方法。涵盖分析查询执行计划,如使用 EXPLAIN 命令及理解关键指标;优化查询语句结构,包括避免子查询、减少函数使用、合理用索引列及避免 “OR”。还介绍了索引类型知识,如 B 树索引、哈希索引等。结合与 MySQL 数据库课程设计相关文章,强调 SQL 语句调优重要性。为提升数据库性能提供实用方法,适合数据库管理员和开发人员。
数据库编程:在PHP环境下使用SQL Server的方法。
看看你吧,就像一个调皮的小丑鱼在一片广阔的数据库海洋中游弋,一路上吞下大小数据如同海中的珍珠。不管有多少难关,只要记住这个流程,剩下的就只是探索未知的乐趣,沉浸在这个充满挑战的数据库海洋中。
51 16
华鼎冷链科技 × 阿里云瑶池数据库,打造全链路协同的智慧冷链新标杆
从 PolarDB 的高性能数据库服务到 AnalyticDB 的强大数据分析,阿里云提供的丰富产品矩阵为华鼎冷链科技构建了全面的解决方案,推动华鼎冷链科技从成本中心向效率中心转型。
如何优化SQL查询以提高数据库性能?
这篇文章以生动的比喻介绍了优化SQL查询的重要性及方法。它首先将未优化的SQL查询比作在自助餐厅贪多嚼不烂的行为,强调了只获取必要数据的必要性。接着,文章详细讲解了四种优化策略:**精简选择**(避免使用`SELECT *`)、**专业筛选**(利用`WHERE`缩小范围)、**高效联接**(索引和限制数据量)以及**使用索引**(加速搜索)。此外,还探讨了如何避免N+1查询问题、使用分页限制结果、理解执行计划以及定期维护数据库健康。通过这些技巧,可以显著提升数据库性能,让查询更高效流畅。
让数据与AI贴得更近,阿里云瑶池数据库系列产品焕新升级
4月9日阿里云AI势能大会上,阿里云瑶池数据库发布重磅新品及一系列产品能力升级。「推理加速服务」Tair KVCache全新上线,实现KVCache动态分层存储,显著提高内存资源利用率,为大模型推理降本提速。
阿里云DTS踩坑经验分享系列|DTS打通SQL Server数据通道能力介绍
SQL Server 以其卓越的易用性和丰富的软件生态系统,在数据库行业中占据了显著的市场份额。作为一款商业数据库,外部厂商在通过解析原生日志实现增量数据捕获上面临很大的挑战,DTS 在 SQL Sever 数据通道上深研多年,提供了多种模式以实现 SQL Server 增量数据捕获。用户可以通过 DTS 数据传输服务,一键打破自建 SQL Server、RDS SQL Server、Azure、AWS等他云 SQL Server 数据孤岛,实现 SQL Server 数据源的流动。
163 0
阿里云DTS踩坑经验分享系列|DTS打通SQL Server数据通道能力介绍
课时2:阿里云数据库:帮用户承担一切数据库风险
阿里云Apsara DB是国内首个通过国家等保三级安全标准的数据库,具备十项国际安全认证。它提供稳定、可靠的在线数据库服务,支持多种主流数据库类型,如MySQL、SQL Server等,覆盖70%市场。基于飞天操作系统和全SSD存储,Apsara DB性能卓越,帮助企业解决运维难题,并提供免费热迁移、自动化运维及顶级DBA专家服务,确保数据安全与高效管理。
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
【YashanDB知识库】原生mysql驱动配置连接崖山数据库

热门文章

最新文章

AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等