- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个问题陈述,其中我必须根据每月考试的成绩获取每个月(从 8 月到 11 月)排名前 50 名的唯一学生。唯一的条件是最终结果必须具有所有唯一的名称,总共 200 个名称。
这是我的数据库结构。
MariaDB [school]> show tables;
+------------------+
| Tables_in_school |
+------------------+
| months |
| overall |
| students |
| scores |
+------------------+
4 rows in set (0.00 sec)
MariaDB [school]> desc students;
+-------+--------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+-------+--------------+------+-----+---------+----------------+
| id | int(4) | NO | PRI | NULL | auto_increment |
| name | varchar(255) | NO | | NULL | |
+-------+--------------+------+-----+---------+----------------+
2 rows in set (0.17 sec)
MariaDB [school]> desc scores;
+------------+--------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+------------+--------------+------+-----+---------+----------------+
| id | int(4) | NO | PRI | NULL | auto_increment |
| month_id | int(4) | NO | | NULL | |
| student_id | int(4) | NO | | NULL | |
| score | varchar(255) | NO | | NULL | |
+------------+--------------+------+-----+---------+----------------+
4 rows in set (0.02 sec)
MariaDB [school]> desc months;
+-------+--------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+-------+--------------+------+-----+---------+----------------+
| id | int(4) | NO | PRI | NULL | auto_increment |
| name | varchar(255) | NO | | NULL | |
+-------+--------------+------+-----+---------+----------------+
2 rows in set (0.02 sec)
为了解决这个问题,我提出了一个解决方案,我将选择 8 月的前 50 名学生,然后选择 9 月的前 50 名不在 8 月前 50 名的学生,然后很快。这是我提出的数据库查询
SELECT student_id FROM scores WHERE month_id = '3' and student_id NOT IN
(SELECT id FROM (SELECT student_id FROM scores WHERE month_id = '2' and student_id NOT IN
(SELECT id FROM (SELECT id FROM scores WHERE month_id = '1' ORDER by scores.id LIMIT 50) august)
ORDER BY scores.id limit 50) september)
ORDER BY scores.id LIMIT 50
显然,我没有得到正确的结果。另外,在最终输出中,我需要从 8 月到 11 月每个月的唯一前 50 名,这意味着总共 200 名学生名单。但我真的很困惑如何实现这一目标。请在这里帮助我。
编辑:我已在 scores
表中添加了 score
列。
看来我没有很好地解释我的问题,因此我给你这个例子。
示例:
考虑一下数据库的实际样子。我想要每个月前 3 名独特的学生,但结果也必须有独特的学生。
因此,10 月的前 3 名学生不应该是 9 月的前 3 名学生。并且 9 月的前 3 名学生不应成为 8 月的前 3 名学生。
MariaDB [deepracer]> select * from scores limit 15;
+----+----------+------------+-------+
| id | month_id | student_id | score |
+----+----------+------------+-------+
| 1 | 1 | 1 | 8.2 |
| 2 | 1 | 6 | 8.3 |
| 3 | 1 | 7 | 8.8 |
| 4 | 1 | 2 | 9.3 |
| 5 | 1 | 4 | 9.4 |
| 6 | 2 | 1 | 8.4 |
| 7 | 2 | 4 | 8.5 |
| 8 | 2 | 6 | 9.4 |
| 9 | 2 | 5 | 9.7 |
| 10 | 2 | 8 | 9.9 |
| 11 | 3 | 3 | 8.1 |
| 12 | 3 | 4 | 8.2 |
| 13 | 3 | 1 | 9.1 |
| 14 | 3 | 2 | 9.3 |
| 15 | 3 | 9 | 9.4 |
+----+----------+------------+-------+
15 rows in set (0.00 sec)
MariaDB [deepracer]> select * from months;
+----+-----------+
| id | name |
+----+-----------+
| 1 | august |
| 2 | september |
| 3 | october |
+----+-----------+
3 rows in set (0.00 sec)
MariaDB [deepracer]> select * from students limit 15;
+----+------+
| id | name |
+----+------+
| 1 | A |
| 2 | B |
| 3 | C |
| 4 | D |
| 5 | E |
| 6 | F |
| 7 | G |
| 8 | H |
| 9 | I |
| 10 | J |
+----+------+
10 rows in set (0.00 sec)
所以,最终的结果输出应该是这样的:
+------+-----------+-------+
| name | month | score |
+------+-----------+-------+
| A | august | 8.2 |
| F | august | 8.3 |
| G | august | 8.8 |
| D | september | 8.5 |
| E | september | 9.7 |
| H | september | 9.9 |
| C | october | 8.1 |
| B | october | 9.3 |
| I | october | 9.4 |
+------+-----------+-------+
我希望这足以清楚地了解问题是什么以及解决方案应该是什么。如果仍有任何困惑,请告诉我。
最佳答案
首先,删除您的表格“总体”。然后将新列“分数”添加到表“分数”中。
实际上,“分数”表中的每一行都代表该学生当月的分数,例如该行代表 1220 号学生 3 月份(第 3 个月)的分数:
ID MonthID StudentId 分数---------- --------- -----3 4 1220 57
接下来,由于这看起来像是一个家庭作业问题,我不会给你 SQL,但你需要做的是:
关于mysql - 获取每个月(8 月至 11 月)的前 50 条记录,但仅限唯一记录,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58575033/
这个问题不太可能帮助任何 future 的访问者;它只与一个小的地理区域、一个特定的时间点或一个非常狭窄的情况有关,这些情况并不普遍适用于互联网的全局受众。为了帮助使这个问题更广泛地适用,visit
我们有自己的 http 服务器适配器,我们用它来托管多个站点。 本网站通过 https 运行。当我们尝试使用 chrome、firefox 或 safari 访问 url 时,它工作正常。该问题仅发生
让我从代码开始……请注意,这不是关于覆盖实例方法的问题——这纯粹涉及扩展方法。此代码用于 Unity3D 游戏引擎,版本 5.3.x public static class ExtentionMeth
我想知道如何开发一个只提供 iOS native 设置应用程序中的一些设置的应用程序,比如很多 cydia 调整,而跳板上没有图标?我的目标只是让一些开关和按钮在我的本地网络上发送命令。 最佳答案 在
好吧,我需要得到两个值来表示两个完整日期之间的距离(没有小时/时间)......在 MySQL 上我们有 PERIOD_DIFF 来获取两个日期之间的差异(只有月份和年份),但我也需要包括日期。 我有
这就是我想要做的。在我的 html 页面上,我必须有 4 种不同的字体大小,其中一种是 10px 20px 30px 40px 然后重置。 当我在 10px 上单击或滚动鼠标时,字体大小会更改并在 d
这个问题在这里已经有了答案: How can I transition height: 0; to height: auto; using CSS? (41 个回答) 关闭 4 年前。
我喜欢 JQuery Mobile,但我的页面中有许多与 JQuery Mobile 不兼容的自定义 Javascript。 我页面中的所有内容都工作正常,但是当我添加 JQuery Mobile 库
我正在尝试创建以下工具提示(不是其中的内容 - 只是框和箭头): 我在让箭头与主框正确融合时遇到问题。 我创建了一个 Fiddle here使用我目前拥有的代码。 您会注意到箭头看起来不错,但不是 1
我是 Javascript 新手。我正在尝试通过练习来学习它。我正在做的这个看起来并不难,但我有一个小问题。 我有一个包含 3 个文本输入和一个提交按钮的表单。通过按下按钮,我获得了字段值并使用这些值
当我将鼠标悬停在按钮上时,我希望菜单滑出。不知何故,只有当我将悬停效果添加到菜单本身而不是按钮时,它才会起作用。我在网上能找到的都是一样的(悬停效果附加到应该滑出的菜单,而不是按钮)。我该如何实现?j
我只想让我的应用程序横向,所以我使用这里提供的方法:i want to make my application only in landscape in android 简而言之,我正在将 andro
我需要将我的共享扩展限制为仅纵向模式。但到目前为止,还不行。有办法吗? @implementation UINavigationController -(BOOL)shouldAutorotate {
不知道是否有人已经看到这个错误。请注意,这仅发生在 Android 4.x 库存浏览器中。它已经在 Android 4 上的 Chrome、旧版浏览器、iOS、Blackberry OS6 和 7、P
如果内容大于容器,我正在尝试构建一个可在 x 和 y 方向滚动的表格。我还希望标题始终在顶部可见。我已经完成了第一部分的工作,标题始终在顶部可见,但是标题列的大小与表格的大小不匹配。 我创建了这个 f
当对图像应用 ImageFilter.blur 时,图像的边缘没有变化。 如何将模糊扩展到边缘? import 'dart:ui'; import 'package:flutter/material.
我正在为 Android 平板电脑编写应用程序。我希望 ScreenOrientation 始终处于“横向”状态,但应用程序应该能够旋转 180°。如果您将平板电脑倒置,则 View 应正确显示并旋转
我有一个带有属性装饰器的类。 class Dispatcher: def __init__(self, url): self._session = None @prop
我只想在模型的查询集中选择几个字段。我看到了这个链接:Django queryset only我以为我实现了它,但我仍然得到了整个查询集。 这是我的项目 View .py: from django.s
我看了看,发现了类似的问题,但它们似乎都是如何将一个列表添加到另一个列表的末尾。 我最近用我在 Excel 中使用的一种技术回答了一个问题,该技术依赖于创建第三列,并使用公式填充来连接每一行的 col
我是一名优秀的程序员,十分优秀!