SQL
文章平均质量分 66
qq_48508157
这个作者很懒,什么都没留下…
展开
-
查询进阶 - 开窗函数 - lag / lead
在上面的示例中,我们使用 Lag 函数获取每个学生的上一次考试成绩(previous_score),使用 Lead 函数获取每个学生的下一次考试成绩(next_score)。如果没有上一次或下一次考试,对应的列将显示为 NULL。请你编写一个 SQL 查询,返回每个学生的详细信息(字段顺序和原始表的字段顺序一致),并且按照分数降序的方式获取每个班级内的学生的前一名学生姓名(prev_name)、后一名学生姓名(next_name)。它可以帮助我们查看上一行的数据。它可以帮助我们查看下一行的数据。原创 2024-08-30 09:55:57 · 859 阅读 · 0 评论 -
查询进阶 - 开窗函数 - row_number
在上面的示例中,我们使用开窗函数 ROW_NUMBER 为每个客户的订单按照订单金额降序排列,并为每个订单分配了一个编号(row_number),并使用 PARTITION BY 子句按照 customer_id 进行分组,并使用 ORDER BY 子句按照 total_amount 进行排序。每一行都有一个唯一的行号,从 1 开始连续递增。请你编写一个 SQL 查询,返回每个学生的详细信息(字段顺序和原始表的字段顺序一致),并且按照分数降序的方式给每个班级内的学生分配一个编号(row_number)。原创 2024-08-30 09:40:57 · 845 阅读 · 0 评论 -
查询进阶 - 开窗函数 - rank
在上面的示例中,我们使用开窗函数 RANK 来为每个客户的订单按照订单金额降序排名(customer_rank),并使用 PARTITION BY 子句按照 customer_id 进行分组,并使用 ORDER BY 子句按照 total_amount 从大到小进行排序。在排名过程中,相同的值将被赋予相同的排名,而不同的值将被赋予不同的排名。请你编写一个 SQL 查询,返回每个学生的详细信息(字段顺序和原始表的字段顺序一致),并且按照分数降序的方式计算每个班级内的学生的分数排名(ranking)。原创 2024-08-30 09:34:42 · 1018 阅读 · 0 评论 -
查询进阶 - 开窗函数 - sum over order by
之前的教程中,我们讲到了 sum over 开窗函数,并且用它实现了分组统计。本节教程我们将学习 sum over 函数的另一种用法:sum over order by,可以实现同组内数据的。举一个应用场景:老师在每个班级里依次点名,每点到一个学生,老师都会记录当前已点到的学生们的分数总和。原创 2024-08-30 09:26:20 · 459 阅读 · 0 评论 -
查询进阶 - 开窗函数 - sum over
在 SQL 中,开窗函数是一种强大的查询工具,它允许我们在查询中进行对分组数据进行计算、。开窗函数可以与聚合函数(如 SUM、AVG、COUNT 等)结合使用,但与普通聚合函数不同,开窗函数不会导致结果集的行数减少。打个比方,可以将开窗函数想象成一种 "透视镜",它能够将我们聚焦在某个特定的分组,同时还能看到整体的全景。本节我们先讲第一个开窗函数:sum over。原创 2024-08-29 15:20:11 · 321 阅读 · 0 评论 -
查询进阶 - 组合查询
现在,我们想要合并这两张表的数据,分别执行 UNION 操作和 UNION ALL 操作。在 SQL 中,组合查询是一种将多个 SELECT 查询结果合并在一起的查询操作。UNION ALL 操作:它也用于将两个或多个查询的结果集合并,包括两种常见的组合查询操作:UNION 和 UNION ALL。请编写一条 SQL 语句,获取所有学生表和新学生表的学生姓名(UNION 操作:它用于将两个或多个查询的结果集合并,即如果两个查询的结果有相同的行,则只保留一行。即如果两个查询的结果有相同的行,则全部保留。原创 2024-08-29 14:51:16 · 257 阅读 · 0 评论 -
查询进阶 - 子查询 - exists
其中,子查询中的一种特殊类型是 "exists" 子查询,用于检查主查询的结果集是否存在满足条件的记录,它返回布尔值(True 或 False),而不返回实际的数据。上述语句中,先遍历客户信息表的每一行,获取到客户编号;然后执行子查询,从订单表中查找该客户编号是否存在,如果存在则返回结果。之前的教程讲到,子查询是一种强大的查询工具,它可以嵌套在主查询中,帮助我们进行更复杂的条件过滤和数据检索。请你编写一个 SQL 查询,使用 exists 子查询的方式来获取。学生的所有数据,返回学生姓名(原创 2024-08-29 14:49:52 · 392 阅读 · 0 评论 -
查询进阶 - 子查询
打个比方,子查询就像是在一个盒子中的盒子,外层查询是大盒子,内层查询是小盒子。在上述 SQL 中,先通过子查询从订单表中过滤查询出了符合条件的客户 id,然后再根据客户 id 到客户信息表中查询客户信息,这样可以少查询很多客户信息数据。当执行包含子查询的查询语句时,数据库引擎会首先执行子查询,然后将其结果作为条件或数据源来执行外层查询。另一个完整的查询语句,内层查询被称为子查询。请你编写一个 SQL 查询,使用子查询的方式来获取存在对应班级的学生的所有数据,返回学生姓名(子查询是指在一个查询语句内部。原创 2024-08-29 14:42:50 · 271 阅读 · 0 评论 -
查询进阶 - 关联查询 - outer join
在 OUTER JOIN 中,包括 LEFT OUTER JOIN 和 RIGHT OUTER JOIN 两种类型,它们分别表示查询左表和右表的所有行(即使没有被匹配),再加上满足条件的交集部分。在 SQL 中,OUTER JOIN 是一种关联查询方式,它根据指定的关联条件,将两个表中满足条件的行组合在一起,并。其实只需要把主表(from 后面的表)和关联表(LEFT JOIN 后面的表)顺序进行调换即可!请你编写一个 SQL 查询,根据学生表和班级表之间的班级编号进行匹配,返回学生姓名(原创 2024-08-29 14:36:29 · 415 阅读 · 0 评论 -
查询进阶 - 关联查询 - inner join
在 SQL 中,INNER JOIN 是一种常见的关联查询方式,它根据两个表之间的关联条件,将满足条件的行组合在一起。我们会发现,使用 INNER_JOIN 后,只有两个表之间存在对应关系的数据才会被放到查询结果中。注意,INNER JOIN 只返回两个表中满足关联条件的交集部分,即在两个表中都存在的匹配行。请你编写一个 SQL 查询,根据学生表和班级表之间的班级编号进行匹配,返回学生姓名(使用 INNER JOIN 进行关联查询,根据员工表和部门表之间的公共字段。原创 2024-08-29 14:30:58 · 251 阅读 · 0 评论 -
查询进阶 - 关联查询 - cross join
请你编写一个 SQL 查询,将学生表和班级表的所有行组合在一起,并返回学生姓名(student_name)、学生年龄(student_age)、班级编号(class_id)以及班级名称(class_name)。注意,在多表关联查询的 SQL 中,我们最好在选择字段时指定字段所属表的名称(比如 e.emp_name),还可以通过给表起别名(比如 employees e)来简化 SQL 语句。,包含以下字段:id(学号)、name(姓名)、age(年龄)、class_id(班级编号);原创 2024-04-28 15:48:14 · 260 阅读 · 0 评论 -
分组聚合 - having 子句
请你编写一个 SQL 查询,统计学生表中班级的总成绩超过 150 分的班级编号(class_id)和总成绩(total_score)。在 SQL 中,HAVING 子句用于在分组聚合后对分组进行过滤。它允许我们对分组后的结果进行条件筛选,只保留满足特定条件的分组。HAVING 子句与条件查询 WHERE 子句的区别在于,WHERE 子句用于在。进行过滤,而 HAVING 子句用于在。原创 2024-04-28 15:31:37 · 209 阅读 · 0 评论 -
分组聚合 - 多字段分组
请你编写一个 SQL 查询,统计学生表中的班级编号(class_id),考试次数(exam_num)和每个班级每次考试的总学生人数(total_num)。有时,单字段分组并不能满足我们的需求,比如想统计学校里每个班级每次考试的学生情况,这时就可以使用多字段分组。多字段分组和单字段分组的实现方式几乎一致,使用。要查询使用多字段分组查询表中。原创 2024-04-28 15:08:07 · 282 阅读 · 0 评论 -
分组聚合 - 单字段分组
在 SQL 中,分组聚合是一种对数据进行分类并对每个分类进行聚合计算的操作。它允许我们按照指定的列或字段对数据进行分组,然后对每个分组应用聚合函数,如 COUNT、SUM、AVG 等,以获得分组后的汇总结果。举个例子:某个学校可以按照班级将学生分组,并对每个班级进行统计。查看每个班级有多少学生、每个班级的平均成绩。这样我们就能够对学校各班的学生情况有一个整体的了解,而不是单纯看个别学生的信息。请你编写一个 SQL 查询,统计学生表中的班级编号(class_id)和每个班级的平均成绩(avg_score)。原创 2024-04-28 14:57:01 · 267 阅读 · 0 评论 -
函数 - 聚合函数
请你编写一个 SQL 查询,汇总学生表中所有学生的总成绩(total_score)、平均成绩(avg_score)、最高成绩(max_score)和最低成绩(min_score)。它们可以对一组数据执行诸如计数、求和、平均值、最大值和最小值等操作。聚合函数通常在 SELECT 语句中配合 GROUP BY 子句使用,用于对分组后的数据进行汇总分析。在 SQL 中,聚合函数是一类用于对数据集进行。原创 2024-04-28 14:46:32 · 189 阅读 · 0 评论 -
函数 - 字符串处理
在 SQL 中,字符串处理是一类用于处理文本数据的函数。它们允许我们对字符串进行各种操作,如转换大小写、计算字符串长度以及搜索和替换子字符串等。字符串处理函数可以帮助我们在数据库中对字符串进行加工和转换,从而满足不同的需求。请你编写一个 SQL 查询,筛选出姓名为 '热dog' 的学生,展示其学号(id)、姓名(name)及其大写姓名(upper_name)。name = '热dog';1)使用字符串处理函数。2)使用字符串处理函数。3)使用字符串处理函数。原创 2024-04-28 14:43:58 · 285 阅读 · 0 评论 -
函数 - 时间函数
在 SQL 中,时间函数是用于处理日期和时间的特殊函数。它们允许我们在查询中操作和处理日期、时间、日期时间数据,从而使得在数据库中进行时间相关的操作变得更加方便和灵活。还有很多时间函数,比如计算两个日期的相差天数、获取当前日期对应的毫秒数等,实际运用时自行查阅即可,此处不做赘述。注意,这里的日期、日期时间和时间将根据当前的系统时间来生成,实际运行结果可能会因为当前时间而不同。请你编写一个 SQL 查询,展示所有学生的姓名(name)和当前日期(列名为 "当前日期")。date () as 当前日期。原创 2024-04-26 18:27:29 · 160 阅读 · 0 评论 -
基础语法 - 条件分支
请你编写一个 SQL 查询,将学生按照年龄划分为三个年龄等级(age_level):60 岁以上为 "老同学",20 岁以上(不包括 60 岁以上)为 "年轻",20 岁及以下、以及没有年龄信息为 "小同学"。举个例子:假设你是一位餐厅的服务员,客人点了不同的菜品,而你需要根据客人点的菜来确定服务的方式。它类似于其他编程语言中的 if else 条件判断语句,允许我们根据不同的条件选择不同的结果返回。返回结果应包含学生的姓名(name)和年龄等级(age_level),并按姓名升序排序。原创 2024-04-26 18:24:46 · 209 阅读 · 0 评论 -
SQL基础语法 - 截断和偏移
Limit用法:limit 起始下标m,长度n ,m是记录开始的index,默认从0开始,表示第一条记录,n是指从第m+1条开始,取n条。通过上述 SQL 查询语句,我们分别选取了待办事项表中的前两个任务和从第三个任务开始的两个任务,实现了数据的截断和偏移。的数据表,它存储了待办事项信息,包括任务名称(task_name)和截止日期(due_date)等。截断和偏移的一个典型的应用场景是分页,即网站内容很多时,用户可以根据页号每次只看部分数据。2)根据任务的编号,直接翻到需要查看的位置(即偏移)原创 2024-04-26 18:20:57 · 398 阅读 · 0 评论