数据库原理SQL查询(习题+知识点)

news2025/3/4 17:24:33

一、查询学生表所有学生记录

1.题目内容+代码编写

select *
from stu;

2.知识点提醒

1)选择表中的所有属性列有两种方法

  • 在select关键字后列出所有列名
  • 若列的显示顺序与其在表中的顺序相同,则也可用 * 表示所有列

二、查询学生表中部分信息

1.题目内容+代码编写

select sno,sname,case when sex = '1' then '男' else '女' end as sex
from stu;

2.知识点提醒

1)性别表示转换(case语句)

  • case语句用于根据条件返回不同的值
  • eg.when sex = '1' then '男':如果sex字段的值为'1',则返回'男'
  • AS关键字:使用AS关键字为列名提供别名,使结果更易于理解

三、查询学生表中的女生信息

1.题目内容+代码编写

select sno as 学号,sname as 姓名
from stu
where sex = '0';

2.知识点提醒

1)where语句

  • 常用于查询满足指定条件的元组
  • 用于条件限定
  • where子句不能用聚集函数作为条件表达式

四、查询学生表中大于19岁的女生

1.题目内容+代码编写

select sno as 学号,sname as 姓名,sex as 性别,mno as 专业,2020-year(birdate) as 年龄,memo as 备注
from stu
where 2020-year(birdate) > 19 and sex = '0';

2.知识点提醒

1)年龄求法

  • 若遇到输出样例需要的是年龄而不是出生年份,需要编写代码进行计算,通常为(给定的当前年份 - year(出生年份))

2)多个条件并存

  • 遇到多个判别条件时,可以使用and进行连接

五、查询年龄18-20之间的学生信息

1.题目内容+代码编写

select sno as 学号,sname as 姓名,sex as 性别,mno as 专业,2020-year(birdate) as 年龄,memo as 备注
from stu
where 2020-year(birdate) between 18 and 20;

2.知识点提醒

1)判别范围圈定

  • 若判别条件为一段范围,可以使用between...and...进行范围的规定

六、查询姓‘李’的学生记录

1.题目内容+代码编写

select sno as 学号,sname as 姓名,sex as 性别,mno as 专业,birdate as 出生日期,memo as 备注
from stu
where sname LIKE '李%';

2.知识点提醒

1)字符串匹配

  • 谓词LIKE可以用来进行字符串的匹配
  • %代表任意长度的字符串,eg.a%b表示以a开头,以b结尾的任意长度的字符串
  • _(下划线)代表任意单个字符,eg.a%b表示以a开头,以b结尾的长度为3的任意字符串

七、查询部分专业的学生

1.题目内容+代码编写

select sno as 学号,sname as 姓名,sex as 性别,mname as 专业
from stu,major
where stu.mno = major.mno and mname in('计算机工程' , '软件工程')
order by sno; 

2.知识点提醒

1)表的连接 

  • 将两个表连接时,可以使用 = 进行等值连接

2)确定集合

  • 谓词IN可以用来查找属性值属于指定集合的元组

3)排序

  • 使用order by进行排序,order by ... desc为降序,order by ... asc为升序(默认值为升序)

八、查询所有学生的平均成绩

1.题目内容+代码编写

SELECT stu.sno as 学号,COALESCE(AVG(sc.grade), 0) as 平均成绩
FROM stu
LEFT JOIN sc ON stu.sno = sc.sno
GROUP BY stu.sno;

2.知识点提醒

1)成绩显示不为NULL

  • COALESCE() 函数确保了即使某个学生没有成绩记录,其平均成绩也不会显示为NULL,而是显示为0

九、查询各专业学生的平均成绩

1.题目内容+代码编写

SELECT mname as 专业,ifnull(AVG(grade),0) as 平均成绩
FROM major left outer join
    (SELECT mno,grade 
    FROM stu,sc 
    WHERE stu.sno=sc.sno)as a on major.mno=a.mno
GROUP BY major.mno
ORDER BY major.mno;

2.知识点提醒

1)连接操作

  • LEFT OUTER JOIN将 major 表和子查询结果a进行左外连接。左外连接保证了即使a表中没有对应的记录,major 表中的记录仍然会出现在结果中。
  • 子查询a从 stu 和 sc 表中选择专业编号 mno 和成绩 grade ,其中stu.sno = sc.sno

十、查询平均成绩高于75分的学生

1.题目内容+代码编写

select sno as 学号,AVG(grade) as 平均成绩
from sc
group by sno
having AVG(grade) > 75;

2.知识点提醒

1)求平均成绩

  • 求平均成绩时,可以使用聚集函数AVG(),且聚集函数不能和where一起使用

2)相同项相加

  • group by子句将查询结果按某一列或多列的值分组,值相等的为一组

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2309589.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

安路FPGA开发入门:软件安装与点灯与仿真(TangDynasty ModelSim)

文章目录 前言软件安装开发软件仿真软件 点灯测试代码编写与编译引脚分配固件下载 仿真测试ModelSim添加仿真库TangDynasty仿真设置进行仿真 后记 前言 最近因为工作需要用安路的FPGA,这里对安路FPGA开发相关流程做个记录。作为测试只需要一个核心板(我这…

浅克隆与深克隆区别

package d12_api_object;public class Test2 {public static void main(String[] args) throws CloneNotSupportedException {//目标:掌握Object类提供的对象克隆方法//1、protected Object clone():对象克隆User u1 new User(1,"min","1120",…

如何实现小数据的大智能?

大数据可以通过从态到势、从感到知的态势感知过程计算出可能性,如各种大模型,而要通过小数据、小样本获得好的预测结果,可以通过从势到态、从知到感的势态知感过程算计出可能性。 一般情况下,大家常常会提到了大数据和小数据在态势…

打开 Windows Docker Desktop 出现 Docker Engine Stopped 问题

一、关联文章: 1、Docker Desktop 安装使用教程 2、家庭版 Windows 安装 Docker 没有 Hyper-V 问题 3、安装 Windows Docker Desktop - WSL问题 二、问题解析 打开 Docker Desktop 出现问题,如下: Docker Engine Stopped : Docker引擎停止三、解决方法 1、检查服务是否…

基于单片机和蓝牙通讯的简易钢琴控制装置设计

摘要:本文设计了一个基于单片机和蓝牙通讯的简易钢琴演奏控制装置,在 Proteus 中设计绘制了系统电路原理图,在 Keil 中编写了单片机控制程序并导入 Proteus电路原理图中进行了软、硬件交互仿真,设置了手机蓝牙串口调试的键盘设置及…

React Native从入门到进阶详解

React Native知识框架从入门到进阶的问题。首先需要结合我搜索到的资料来整理出结构化的内容。证据中有多本书籍和文章,可能会涉及不同的章节和重点,需要仔细梳理。 首先,根据邱鹏源的《React Native精解与实战》将知识分为入门和进阶两大部分…

STL——list的介绍和模拟实现

前言 本篇博客我们将要开始介绍list这个容器,list是带头双向循环链表,STL标准模板库中实现了list这样方便我们去使用,那么本篇博客我们将脱下list的神秘外衣,介绍它的使用以及模拟实现。 list的介绍 list的底层是带头双向循环链…

go前后端开源项目go-admin,本地启动

https://github.com/go-admin-team/go-admin 教程 1.拉取项目 git clone https://github.com/go-admin-team/go-admin.git 2.更新整理依赖 go mod tidy会整理依赖,下载缺少的包,移除不用的,并更新go.sum。 # 更新整理依赖 go mod tidy 3.编…

go 分布式redis锁的实现方式

go 语言以高并发著称。那么在实际的项目中 经常会用到锁的情况。比如说秒杀抢购等等场景。下面主要介绍 redis 布式锁实现的两种高并发抢购场景。其实 高并发 和 分布式锁 是一个互斥的两个状态: 方式一 setNX: 使用 redis自带的API setNX 来实现。能解决…

深入理解递归:从原理到C++实践

什么是递归? 递归(Recursion)是编程中一种强大的技术,其核心思想是:函数直接或间接地调用自身。如同俄罗斯套娃一般,每个函数调用都会解开问题的一个层级,直到达到基础条件。 递归三要素&…

MyBatis-Plus 入门详解:从零搭建高效持久层

一、MyBatis-Plus 简介 MyBatis-Plus(简称 MP)是 MyBatis 的增强工具,在保留 MyBatis 原生功能的基础上,提供了全自动化的 CRUD 操作、强大的分页插件、代码生成器等功能,显著减少开发工作量。与原生 MyBatis 相比&…

阿里云物联网获取设备属性api接口:QueryDevicePropertyData

阿里云物联网接口:QueryDevicePropertyData 说明:调用该接口查询指定设备或数字孪生节点,在指定时间段内,单个属性的数据 比如提取上传到物联网的温度数据 api文档:QueryDevicePropertyData_物联网平台_API文档-阿里…

歌曲分类和流行度预测

1. 项目介绍 本项目从kaggle平台上下载了数据集,该数据集包含了3万多首来自Spotify API 的歌曲,共有23个特征。首先对数据集进行预处理,如重复行、缺失值、标准化处理等。再对预处理后的数据进行探索性分析,观察各变量的分布情况&…

不重启mysql情况下排查慢SQL

查状态 mysql> show variables like %slow_query_log%; 开启慢日志 mysql> set global slow_query_logON; 设置1s超时 mysql> set global long_query_time1; 如果想更小,可以设置0.5 查看慢SQL的日志 cat /var/lib/mysql/localhost-slow.log &…

27、Java 反射机制

15-1 Java 反射机制概述 Reflection(反射)是被视为动态语言的关键 动态语言:在运行时代码可以根据某些条件改变自身结构。如 C#\JavaScript\PHP 静态语言:运行时结构不可变的语言。如 Java\C\C 问题:通过直接new的方…

Android 端侧运行 LLM 框架 MNN 及其应用

MNN Chat Android App - 基于 MNN 引擎的智能聊天应用 一、MNN 框架简介与工作原理1.1 什么是 MNN?1.2 MNN 的工作原理 二、MNN Chat Android App2.1 MNN Chat 的功能2.2 MNN Chat 的优势2.3 MNN Chat Android App 的使用 三、总结 随着移动端人工智能需求的日益增长…

FPGA学习(一) —— 四位全加器

FPGA学习(一) —— 四位全加器 文章目录 FPGA学习(一) —— 四位全加器一、半加器1、半加器的真值表2、Verilog代码实现3、RTL原理图4、波形仿真 二、一位全加器1、一位全加器真值表2、Verilog代码实现3、RTL原理图4、波形仿真 三…

PHP:IDEA开发工具配置XDebug,断点调试

文章目录 一、php.ini配置二、IDEA配置 一、php.ini配置 [xdebug] zend_extension"F:\wamp64\bin\php\php7.4.0\ext\php_xdebug-2.8.0-7.4-vc15-x86_64.dll" xdebug.remote_enable on xdebug.remote_host 127.0.0.1 xdebug.remote_port 9001 xdebug.idekey"…

LINUX网络基础 - 网络编程套接字,UDP与TCP

目录 前言 一. 端口号的认识 1.1 端口号的作用 二. 初识TCP协议和UDP协议 2.1 TCP协议 TCP的特点 使用场景 2.2 UDP协议 UDP的特点 使用场景 2.3 TCP与UDP的对比 2.4 思考 2.5 总结 三. 网络字节序 3.1 网络字节序的介绍 3.2 网络字节序思考 四. socket接口 …

QT实现单个控制点在曲线上的贝塞尔曲线

最终效果: 一共三个文件 main.cpp #include <QApplication> #include "SplineBoard.h" int main(int argc,char** argv) {QApplication a(argc, argv);SplineBoard b;b.setWindowTitle("标准的贝塞尔曲线");b.show();SplineBoard b2(0.0001);b2.sh…